mybatis列印SQL日誌最終解決方案
阿新 • • 發佈:2019-01-29
問題
在程式除錯時想要mybatis列印SQL日誌,但它並沒有類似hibernate所提供的showsql功能,因此只能通過配置log4j日誌輸出級別的方式來列印sql。但網上搜到的答案几乎都是下面的配置方式:
log4j.rootLogger=info,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
###顯示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
rootLogger的級別是info,是為了防止其他類輸出debug的除錯程式碼(rootLogger若設為debug了,mybatis也沒必要再設定了)。但這段程式碼根本沒有作用!
解決方案
經過一系列的嘗試,終於找到了解決方案,直接修改dao層(將com.github.vita.code.dao
修改為你專案中dao的路徑)的輸出級別即可:
<loggers>
<Logger name="com.github.vita.code.dao" level="trace" />
<root level="info">
<appender-ref ref="Console"/>
</root>
</loggers>
上面的是log4j 2的XML配置,log4j中對應的配置為log4j.logger.com.github.vita.code.dao=trace