MyException - 我的异常网
当前位置:我的异常网» SQL » ibatis在debug时打印完整的SQL话语

ibatis在debug时打印完整的SQL话语

www.MyException.Cn  网友分享于:2013-08-25  浏览:22次
ibatis在debug时打印完整的SQL语句

转载于:http://www.cnblogs.com/warison2008/archive/2010/10/13/1850262.html

 

这些年做的项目中,对持久层的选型更多的是基于ibatis,而且自己涂鸦的系统开发框架数据层操作也是居于ibatis实现的,不为别的,就因为ibatis使用的是纯jdbc操作。

      时下流行凡是都“原始回归”,“如果能把ibatis进行更好地理解和扩展,也不乏为一个优秀的杜撰框架”,基于这样的想法,好长时间里,我一直是钟情 于ibatis的源码学习,自然从中也学到了很多有用的东西,设计模式、算法分析、构建思想和一些优秀的API实体类工具等。

       好,先来几句赞美ibatis的浮夸。

      ibatis 是一个 O/R Mapping 解决方案, ibatis 最大的特点就是小巧,上手很快。如果你不需要太多复杂的功能, ibatis 是能满足你的要求又足够灵活的 最简单的解决方案。ibatis 以SQL开发的工作量和数据库移植性上的让步,为系统 设计提供了更大的自由空间。

      ibatis 底层采用纯JDBC操作,要求操作人员直接编写sql进行操作,光从这点看,ibatis本身就大大地提高数据层操作的透明度。

      好啦,改干正事了,这里我主要解决的就是一个常见的问题,即使用ibatis时需要在控制台或日志文件中打印其当前执行的完整sql,而不是常见的参数 问号 ? 语句。(这里主要基于ibatis2.0以上版本)。

 

步骤:

      1.网上下一个源码文件(没有可找我,我发一份给你)

      2. 最终API执行流程,这里以insert为例。 具体顺序如下图:

      3. 最终根源找到,即修改com.ibatis.sqlmap.engine.execution.SqlExecutor即可。

在代码66行处有如下方法

public int executeUpdate(StatementScope statementScope, Connection conn, String sql, Object[] parameters) throws SQLException {

}

insert最终执行的就是这个方法,恩,就是它了,改吧

      4. 在类体中引入日志打印工具

private static final Log log = LogFactory.getLog(SqlExecutor.class);

 

     5. 添加debug下执行sql打印信息

在ps.execute(); 执行前添加如下:

 

代码
if (log.isDebugEnabled()) { int count = ps.getParameterMetaData().getParameterCount(); for ( int i = 0 ; i < count; i ++ ) { sql = sql.replaceFirst( " \\? " , parameters[i].getClass().getName().equals( " java.lang.String " ) ? " ' " + parameters[i].toString() + " ' " : parameters[i].toString()); } log.debug( " ===当前执行SQL为=== " + sql + " . " ); }

 

 

 

 

还是贴一下完整的方法吧,省得有人抱怨我,O(∩_∩)O哈哈~

代码
public int executeUpdate(StatementScope statementScope, Connection conn, String sql, Object[] parameters) throws SQLException { ErrorContext errorContext = statementScope.getErrorContext(); errorContext.setActivity( " executing update " ); errorContext.setObjectId(sql); PreparedStatement ps = null ; setupResultObjectFactory(statementScope); int rows = 0 ; try { errorContext.setMoreInfo( " Check the SQL Statement (preparation failed). " ); ps = prepareStatement(statementScope.getSession(), conn, sql); setStatementTimeout(statementScope.getStatement(), ps); errorContext.setMoreInfo( " Check the parameters (set parameters failed). " ); statementScope.getParameterMap().setParameters(statementScope, ps, parameters); errorContext.setMoreInfo( " Check the statement (update failed). " ); // 打印调试信息 start if (log.isDebugEnabled()) { int count = ps.getParameterMetaData().getParameterCount(); for ( int i = 0 ; i < count; i ++ ) { sql = sql.replaceFirst( " \\? " , parameters[i].getClass().getName().equals( " java.lang.String " ) ? " ' " + parameters[i].toString() + " ' " : parameters[i].toString()); } log.debug( " ===当前执行SQL为=== " + sql + " . " ); } // 打印调试信息 end ps.execute(); rows = ps.getUpdateCount(); } finally { closeStatement(statementScope.getSession(), ps); } return rows; }

 

 

 

     Ok,主要的工作就是这样,下面开启commons-logging\log4j的debug模式测试一下吧。其他方式的API方法修改也累似了。

     可能你会鄙视我,就这点三脚猫还出来“现眼”,笑笑,没事了,反正我就是想和大伙分享下自己的心得。自然对一个框架的扩展修改不会仅限于此(如 sqlmap一个节点下同时执行多个sql、主子表同时保存一次操作中保证彼此外键的同时赋值关联、selectkey变种扩展为classkey即唯一 主键由某个类实现而不是数据库sql,等等这些都是很容易的事情),如果是这样那我还不如回家种田去。可是罪恶的约束限制我只能写这么多,在中国嘛,就是 这样了,到哪里都《保密协议》,悲哀。。。。。。

     后期,如有时间,我会说说ibatis中关于connecting,事物,对象缓存等一些自己的理解,更多的是一些读懂代码的体会。

      【最近在弄自创的WMframework,2.0版本,设计,代码实现基本上完成,还差一些文档说明,等做好那天再和大伙分享吧,不过不要笑我啊,因为我就是涂鸦而已。】

1 楼 dongbiying 2011-12-14  
    大哥 你怎么弄的呀 。。。
2 楼 雁栖湖 2012-05-06  
还能是怎么弄的啊,当然是ctrl + c and ctrl + v, 我刚在博客园看完,又看到这个  蛋疼

文章评论

60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
10个调试和排错的小建议
10个调试和排错的小建议
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
一个程序员的时间管理
一个程序员的时间管理
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
我的丈夫是个程序员
我的丈夫是个程序员
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
那些争议最大的编程观点
那些争议最大的编程观点
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
程序员应该关注的一些事儿
程序员应该关注的一些事儿
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员的鄙视链
程序员的鄙视链
中美印日四国程序员比较
中美印日四国程序员比较
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
每天工作4小时的程序员
每天工作4小时的程序员
代码女神横空出世
代码女神横空出世
 程序员的样子
程序员的样子
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
我是如何打败拖延症的
我是如何打败拖延症的
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
漫画:程序员的工作
漫画:程序员的工作
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
编程语言是女人
编程语言是女人
程序员都该阅读的书
程序员都该阅读的书
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
程序员必看的十大电影
程序员必看的十大电影
为什么程序员都是夜猫子
为什么程序员都是夜猫子
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
程序员和编码员之间的区别
程序员和编码员之间的区别
鲜为人知的编程真相
鲜为人知的编程真相
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
总结2014中国互联网十大段子
总结2014中国互联网十大段子
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
旅行,写作,编程
旅行,写作,编程
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有