Mybatis在控制台打印sql

搜索资料只能利用log4j实现
这里只是添加了一些说明

网上log4j.properties文件中mybatis打印sql的配置

#DEBUG < INFO < WARN < ERROR < FATAL
### set log levels ###
log4j.rootLogger=debug, stdout

### 把日志信息输出到控制台 ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n

### show sql ###
log4j.logger.com.ibatis=debug
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=debug
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=debug
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=debug
log4j.logger.java.sql.Connection=debug
log4j.logger.java.sql.Statement=debug
log4j.logger.java.sql.PreparedStatement=debug

这种方法是可以打印sql的,但是因为是debug级别,导致控制台输出了很多无用的debug信息,对检查sql依然不好找,所以这种方法不推荐

优化解决方案

因为我们一般设置log4j都是info级别的log4j.rootLogger=info, stdout,但log4j支持对各个模块设置日志级别,所以只需要对打印sql的那一些类设置debug级别就可以了,配置如下:

在log4j.properties中添加下面一行

log4j.logger.com.web.dao=debug

语法解释:log4j.logger.[package].[class]=[level],[appender]

  • [package] 包路径,如上面的 com.web.dao 包
  • [class] 类名,可不写
  • [level] 日志级别, debug
  • [appender] 日志输出的地址,可忽略

这样就可以把com.web.dao包下的所有类里的sql打印出来

如:

2016-09-22 00:00:00 DEBUG [com.web.dao.UserMapper.selectByPrimaryKey] ==>  Preparing: select `id` ,`name` ,`pwd` from user where `id` = ? 
2016-09-22 00:00:00 DEBUG [com.web.dao.UserMapper.selectByPrimaryKey] ==> Parameters: 1(String)
2016-09-22 00:00:00 DEBUG [com.web.dao.UserMapper.selectByPrimaryKey] <==      Total: 1
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值