`

IBATIS2知识点二:放出IBATIS2.3.4.8--守护IBATIS2

阅读更多

长话短说,偶在博客开出了IBATIS2栏目,为的是给守护IBATIS2的同僚以信心,勿盲目的跟风技术,蜻蜓点水(毕竟遗留项目升级不易)!

IBATIS2是有缺陷,但作为SQL MAP开发,拥有它足以!IBATIS3做了优化、做了调整,完全处于不兼容IBATIS2状态,但作为SQL MAP模式,若仅仅停留在代码重构、优化dynamic sql方面,也不值得我们去跟风!

我之所以力挺IBATIS这种SQL MAP模式,是应为它有“一站式的”ORM 框架所不及的应用环境(eg.以局外人的角度,不干预库表设计,完全透明化提供DAO层规范化服务),详见博文IBATIS2序:T[.WOLF]开场白

对于IBATIS的缺陷,大家谈的比较多的可能有以下几点:

①对数据库移植性支持不好;

②要自行编写sql,影响开发速度;

③数据库连接池方面做的不够;

④没有解决关联1:M/M:N存在N+1选择问题;

⑤分页采用逻辑分页,不支持大数据量选取,进而导致分页相关功能失效;

......

从相对论的角度来看,其实这些问题都不是什么大问题:

①对数据库移植性支持不好。有多少项目必须要支持多数据库呢?尤其是后台型项目!

②要自行编写sql,影响开发速度。“君子性非异也,善假于物也。”为何不借助于工具或自行写个代码生成器呢?自行写sql,其实这也正是SQL MAP灵活性的核心所在!

③数据库连接池方面做的不够。关于这个问题,我们完全可以借助于Spring来弥补啊,充分发挥Spring粘合剂的优势!

④没有解决关联1:M/M:N存在N+1选择问题。这个问题在IBATIS2.2.0借助于groupBy关键字都已经解决了,之所以会有朋友认为尚未解决我猜是受中文文档更新不及时误导所致,官方提供的中文文档iBATIS-SqlMaps-2_cn.pdf更新时间是2004年6月17日,而问题解决的英文文档iBATIS-SqlMaps-2_en.pdf更新时间是2006年8月9日!(注:并非利用解决N+1问题总是最好的,还要综合考虑,也许懒加载更适合)

⑤分页采用逻辑分页,不支持大数据量选取,进而导致分页相关功能失效。这的确是一个硬伤,但并不是无药可救。网上有很多朋友通过继承SqlExecutor实现物理分页,并通过反射替换应用中真实sql执行器(详见http://pengfeng.iteye.com/blog/200772http://blog.csdn.net/cyoubunketu/archive/2009/06/06/4246676.aspx--刚去google的)。

 

看到很多朋友为了⑤忙碌,要做IBATIS2的守护者,今天放出我对⑤的解决方案,和朋友们的做法大同小异,下面简单的介绍下。

发布版本:iBatis2.3.4.8;《见附件》

基础版本:iBatis2终结版(V2.3.4.726)

解决的问题:①支持数据库物理分页选取;②消除接口PaginatedList及实现类PaginatedDataList过时注释;
注意事项:①若您采用的是Oracle数据库,则对您完全透明,无需做任何调整;
                ②若您采用的是MySQL数据库,则需要修改dialect.properties属性文件;
                   文件的位置:com/ibatis/ext/sqlmap/engine/dialect/dialect.properties
                   修改的方法:将dialectClass=com.ibatis.ext.sqlmap.engine.dialect.Dialect4Oracle
                         改为dialectClass=com.ibatis.ext.sqlmap.engine.dialect.Dialect4MySQL
               ③若您采用其他数据库,则需要实现接口com.ibatis.ext.sqlmap.engine.dialect.Dialect,并按②修改dialect.properties属性文件。
附Oracle版的Dialect接口实现代码:

package com.ibatis.ext.sqlmap.engine.dialect;

public class Dialect4Oracle implements Dialect {

 public boolean supportPhysicLimit() {
  return true;
 }
 public String sqlLimitWrapper(String sql, long offset, long maxsize) {
  if (sql.indexOf("select") == -1)
   throw new RuntimeException(
     "the parameter sql of Dialect4Oracle.sqlWrapper is not a valid select sql:\n"
       + sql);
  sql = sql.trim();
  /* get fields of raw sql,if your ibatis version is lower than version2.2.0 
               or the ibatis version does not support more columns selected than mapped in conf.xml
  String sqlFields = sql
    .substring("select".length(), sql.indexOf("from"));
  */
  // construct rule sql
  StringBuffer dSQL = new StringBuffer(sql.length() + 100);
  //dSQL.append("select").append(sqlFields).append("from (");
  dSQL.append("select").append(" * ").append("from (");
  dSQL.append("select tab_.*,rownum rownum_ from (").append(sql).append(
    ")");
  dSQL.append(" tab_ where rownum<=").append(offset + maxsize);
  dSQL.append(")");
  dSQL.append(" where rownum_>").append(offset);
  //System.out.println(dSQL.toString());
  return dSQL.toString();
 }
}

 
附分页调用代码片段(非WEB模式):

PaginatedDataList pagerList = (PaginatedDataList) service.userDaoIntf.queryForPaginatedList("selectUserList", aUser, 10);
do {
 if(!pagerList.isEmpty()) {
  Iterator itr = pagerList.iterator();
  while(itr.hasNext()) {
   //do something,for example as follows
   System.out.println(((User)itr.next()).getUsername());
  }
 }
} while(pagerList.nextPage());

 
在IBATIS3尚未走向成熟,尚未得到多方支持,尚未表现出优秀的特征之前,请先沉住气,让我们共同守护IBATIS2,这也是我前不久开出IBATIS2栏目打算介绍IBATIS2的基础知识、最佳实践的初衷!

 

特别提示:以Hibernate为代表的一站式ORM思想不同于以IBTIS这种SQL Map方式的半自动化的ORM,两者各有千秋,选谁&用谁视实际项目情况而定,这是我一贯坚持认为的。关于这两个框架的相关知识都将会有所介绍,以便共享知识,相互交流。

分享到:
评论
14 楼 redsnow_fenglin 2011-08-15  
Speak-shuai 写道
bushkarl 写道
rar 解压缩密码多少呢?

我也想问这个问题

rar里面有注释哦:
解压码:http://redsnow-fenglin.javaeye.com/
13 楼 Speak-shuai 2011-05-19  
bushkarl 写道
rar 解压缩密码多少呢?

我也想问这个问题
12 楼 bushkarl 2011-02-18  
rar 解压缩密码多少呢?
11 楼 shiwei2006 2011-02-18  
支持楼主,自己可以根据实际项目情况再进行适当修改就行了。关于项目的兼容性和随时可以更换数据库这样的需求应该是很少的。
10 楼 redsnow_fenglin 2010-08-16  
joyfun 写道
看楼主的说明 主要加上了分页 其实可以以插件的形式发布 这样兼容性也还好
mybatis2.3.5已经发布了
http://code.google.com/p/mybatis/downloads/list?can=2


对于仍有第三方升级可能的情况,若我们添加扩展功能,则您的建议很好的!
对于已经是终版的第三方,若我们处理的是她的硬伤,则兼顾性能,对其源码升级应该是较好的选择。同时,这样以来可以顺便消除讨厌的分页过期注释!

此外,mybatis2.3.5(是ibatis2.3.4的升版,所谓的ibatis3,被直接更名了),关于她的分页是采用的您的思想--扩展插件,在javaeye上有两篇样例博文http://melin.iteye.com/blog/491713和http://badqiu.iteye.com/blog/493884!
9 楼 joyfun 2010-08-13  
看楼主的说明 主要加上了分页 其实可以以插件的形式发布 这样兼容性也还好
mybatis2.3.5已经发布了
http://code.google.com/p/mybatis/downloads/list?can=2
8 楼 songfantasy 2010-08-13  
支持ibatis2,3已经改名字了。晕
7 楼 redsnow_fenglin 2010-08-11  
<p>修正一个BUG: <br>因之前发布的ibatis2.3.4.8是在Application下测试通过的,但今天发现在WEB模式下由spring加载报错说加载不到dialectClass,原因是类加载器的问题,现已修正。</p>
<p>代码在com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate的无参构造子中,修正前后分别为: <br>修正前:</p>
<pre name="code" class="java">                /**
* Default constructor
*/
public SqlMapExecutorDelegate() {
mappedStatements = new HashMap();
cacheModels = new HashMap();
resultMaps = new HashMap();
parameterMaps = new HashMap();

sqlExecutor = new EnhancedSqlExecutor();
InputStream is = ClassLoader
.getSystemClassLoader()
.getResourceAsStream(
"com/ibatis/ext/sqlmap/engine/dialect/dialect.properties");
Properties props = new Properties();
try {
props.load(is);
String dialectClass = props.getProperty("dialectClass");
((EnhancedSqlExecutor) sqlExecutor).setDialect((Dialect) Class
.forName(dialectClass).newInstance());

} catch (Exception e) {
throw new RuntimeException(
new StringBuilder(
"SqlMapExecutorDelegate not find the dialectClass in com/ibatis/ext/sqlmap/engine/dialect/dialect.properties,detail info:\n"
+ e.getMessage()).toString());
}
typeHandlerFactory = new TypeHandlerFactory();
dataExchangeFactory = new DataExchangeFactory(typeHandlerFactory);
}</pre>
<p> <br>修正后:</p>
<pre name="code" class="java">/**
* Default constructor
*/
public SqlMapExecutorDelegate() {
mappedStatements = new HashMap();
cacheModels = new HashMap();
resultMaps = new HashMap();
parameterMaps = new HashMap();

sqlExecutor = new EnhancedSqlExecutor();
String dialectINI = "com/ibatis/ext/sqlmap/engine/dialect/dialect.properties";
InputStream is = SqlMapExecutorDelegate.class.getClassLoader().getResourceAsStream(dialectINI);
if(is == null) {
is = Thread.currentThread().getContextClassLoader().getResourceAsStream(dialectINI);
if(is == null) {
is = ClassLoader.getSystemClassLoader().getResourceAsStream(dialectINI);
}
}
Properties props = new Properties();
try {
props.load(is);
String dialectClass = props.getProperty("dialectClass");
((EnhancedSqlExecutor) sqlExecutor).setDialect((Dialect) Class
.forName(dialectClass).newInstance());

} catch (Exception e) {
throw new RuntimeException(
new StringBuilder(
"SqlMapExecutorDelegate not find the dialectClass in com/ibatis/ext/sqlmap/engine/dialect/dialect.properties,detail info:\n"
+ e.getMessage()).toString());
}
typeHandlerFactory = new TypeHandlerFactory();
dataExchangeFactory = new DataExchangeFactory(typeHandlerFactory);
}</pre>
<p> <br>重新发布一份见附件!</p>
<p> </p>
6 楼 shihujie861028 2010-08-03  
使用Ibatis有段时间了,ibatis 还是挺不错的,支持的要!
5 楼 mqlfly2008 2010-08-03  
使用 ibatis ,支持
4 楼 鱼言风语 2010-08-01  
握个爪,找到同志了!

俺已经修改了几处CoolSQL,使其用起来更爽

现在在做一个修改,让其能支持多表查询自动生成BO、DAO、SqlMap
3 楼 aimer311 2010-08-01  
上个月我还在很爽的使用abator生成代码,现在正徘徊在hibernate的OneToMany,ManyToMany中。我们掌控的越少,不可预料的结果就越会发生。
还是比较习惯sql的感觉。
2 楼 Brera 2010-07-31  

手上有中英文的文档,一直没有去读英文的
刚刚去看了才发现,确实不同
今晚得好好读读
1 楼 lyb520320 2010-07-31  
好帖,我是IBatis的忠实拥护者,共同进步!

相关推荐

    Spring+ibatis框架

    ### Spring+ibatis框架知识点详解 #### 一、Spring+ibatis框架简介 Spring与ibatis(现称为MyBatis)都是Java平台下非常流行的开源框架。Spring主要提供了一个轻量级的应用容器来管理对象的生命周期及依赖注入,而...

    实时监控体系:基于Prometheus的API性能指标可视化方案.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    5个提升DeepSeekAPI生成质量的调参技巧,开发者必看!.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    ACM动态规划模板-区间修改线段树问题模板

    ACM动态规划模板-区间修改线段树问题模板

    深度解析C语言调试技巧:VSCode+GDB实战排错指南.pdf

    # 踏入C语言的奇妙编程世界 在编程的广阔宇宙中,C语言宛如一颗璀璨恒星,以其独特魅力与强大功能,始终占据着不可替代的地位。无论你是编程小白,还是有一定基础想进一步提升的开发者,C语言都值得深入探索。 C语言的高效性与可移植性令人瞩目。它能直接操控硬件,执行速度快,是系统软件、嵌入式开发的首选。同时,代码可在不同操作系统和硬件平台间轻松移植,极大节省开发成本。 学习C语言,能让你深入理解计算机底层原理,培养逻辑思维和问题解决能力。掌握C语言后,再学习其他编程语言也会事半功倍。 现在,让我们一起开启C语言学习之旅。这里有丰富教程、实用案例、详细代码解析,助你逐步掌握C语言核心知识和编程技巧。别再犹豫,加入我们,在C语言的海洋中尽情遨游,挖掘无限可能,为未来的编程之路打下坚实基础!

    10个高效调用DeepSeekAPI的技巧:从请求优化到缓存策略.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    基于Python语言的PersonRelationKnowledgeGraph设计源码

    本项目为Python语言开发的PersonRelationKnowledgeGraph设计源码,总计包含49个文件,涵盖19个.pyc字节码文件、12个.py源代码文件、8个.txt文本文件、3个.xml配置文件、3个.png图片文件、2个.md标记文件、1个.iml项目配置文件、1个.cfg配置文件。该源码库旨在构建一个用于表示和查询人物关系的知识图谱系统。

    成本优化指南:通过Token计算模型将API费用降低57%的秘诀.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    大华智能物联平台,的对接其他接口的API,可以获得视频拉流的flv/hls/rstp 的拉流地址,demo项目为springBoot项目,可以通过摄像头的视频通道,获取到实时拉流的uRl

    rtsp实时预览接口URL:/evo-apigw/admin/API/MTS/Video/StartVideo HLS、FLV、RTMP实时预览接口方式 :接口URL/evo-apigw/admin/API/video/stream/realtime 参数名 必选 类型 说明 data true string Json串 +channelId true string 视频通道编码 +streamType true string 码流类型:1=主码流, 2=辅码流,3=辅码流2 +type true string 协议类型:hls,hlss,flv,flvs,ws_flv,wss_flv,rtmp hls:http协议,m3u8格式,端口7086; hlss:https协议,m3u8格式,端口是7096; flv:http协议,flv格式,端口7886; flvs:https协议,flv格式,端口是7896; ws_flv:ws协议,flv格式,端口是7886; wss_flv:wss协议,flv格式,端口是7896; rtmp:rtmp协议,端口是1975;

    Simulink永磁风机飞轮储能系统二次调频技术研究:频率特性分析与参数优化,Simulink永磁风机飞轮储能二次调频技术:系统频率特性详解及参数优化研究参考详实文献及两区域系统应用,simulink

    Simulink永磁风机飞轮储能系统二次调频技术研究:频率特性分析与参数优化,Simulink永磁风机飞轮储能二次调频技术:系统频率特性详解及参数优化研究参考详实文献及两区域系统应用,simulink永磁风机飞轮储能二次调频,系统频率特性如下,可改变调频参数改善频率。 参考文献详细,两区域系统二次调频。 ,核心关键词: 1. Simulink 2. 永磁风机 3. 飞轮储能 4. 二次调频 5. 系统频率特性 6. 调频参数 7. 改善频率 8. 参考文献 9. 两区域系统 以上关键词用分号(;)分隔,结果为:Simulink;永磁风机;飞轮储能;二次调频;系统频率特性;调频参数;改善频率;参考文献;两区域系统。,基于Simulink的永磁风机与飞轮储能系统二次调频研究:频率特性及调频参数优化

    MATLAB驱动的ASR防滑转模型:PID与对照控制算法对比,冰雪路面条件下滑移率与车速轮速对照展示,MATLAB驱动的ASR防滑转模型:PID与对照控制算法对比,冰雪路面条件下滑移率与车速轮速对照图

    MATLAB驱动的ASR防滑转模型:PID与对照控制算法对比,冰雪路面条件下滑移率与车速轮速对照展示,MATLAB驱动的ASR防滑转模型:PID与对照控制算法对比,冰雪路面条件下滑移率与车速轮速对照图展示,MATLAB驱动防滑转模型ASR模型 ASR模型驱动防滑转模型 ?牵引力控制系统模型 选择PID控制算法以及对照控制算法,共两种控制算法,可进行选择。 选择冰路面以及雪路面,共两种路面条件,可进行选择。 控制目标为滑移率0.2,出图显示车速以及轮速对照,出图显示车辆轮胎滑移率。 模型简单,仅供参考。 ,MATLAB; ASR模型; 防滑转模型; 牵引力控制系统模型; PID控制算法; 对照控制算法; 冰路面; 雪路面; 控制目标; 滑移率; 车速; 轮速。,MATLAB驱动的ASR模型:PID与对照算法在冰雪路面的滑移率控制研究

    芯片失效分析方法介绍 -深入解析芯片故障原因及预防措施.pptx

    芯片失效分析方法介绍 -深入解析芯片故障原因及预防措施.pptx

    4131_127989170.html

    4131_127989170.html

    PostgreSQL自动化部署与优化脚本:智能化安装、安全加固与监控集成

    内容概要:本文提供了一个全面的PostgreSQL自动化部署解决方案,涵盖智能环境适应、多平台支持、内存与性能优化以及安全性加强等重要方面。首先介绍了脚本的功能及其调用方法,随后详细阐述了操作系统和依赖软件包的准备过程、配置项的自动生成机制,还包括对实例的安全性和监控功能的强化措施。部署指南给出了具体的命令操作指导,便于新手理解和执行。最后强调了该工具对于不同硬件条件和服务需求的有效应对能力,特别是针对云计算环境下应用的支持特点。 适合人群:对PostgreSQL集群运维有一定基础并渴望提高效率和安全性的数据库管理员及工程师。 使用场景及目标:本脚本能够帮助企业在大规模部署时减少人工介入时间,确保系统的稳定性与高性能,适用于各类需要稳定可靠的数据库解决方案的企业或机构,特别是在大数据量和高并发事务处理场合。 其他说明:文中还提及了一些高级功能如自动备份、流复制等设置步骤,使得该方案不仅可以快速上线而且能满足后续维护和发展阶段的要求。同时提到的技术性能数据也为用户评估其能否满足业务需求提供了直观参考。

    房地产开发合同[示范文本].doc

    房地产开发合同[示范文本].doc

    成本优化实战:DeepSeekAPI的Tokens计算与计费策略拆解.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    安全必读:DeepSeek接口调用中的数据加密与合规实践.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

    工程技术承包合同[示范文本].doc

    工程技术承包合同[示范文本].doc

    蓝桥杯开发赛作品源码【基于C语言】

    蓝桥杯开发赛【作品源码】

    深度解析DeepSeek语义分析API:实现情感分析与意图识别的进阶技巧.pdf

    在日常的工作和学习中,你是否常常为处理复杂的数据、生成高质量的文本或者进行精准的图像识别而烦恼?DeepSeek 或许就是你一直在寻找的解决方案!它以其高效、智能的特点,在各个行业都展现出了巨大的应用价值。然而,想要充分发挥 DeepSeek 的优势,掌握从入门到精通的知识和技能至关重要。本文将从实际应用的角度出发,为你详细介绍 DeepSeek 的基本原理、操作方法以及高级技巧。通过系统的学习,你将能够轻松地运用 DeepSeek 解决实际问题,提升工作效率和质量,让自己在职场和学术领域脱颖而出。现在,就让我们一起开启这场实用又高效的学习之旅吧!

Global site tag (gtag.js) - Google Analytics