1. 程式人生 > >mybatis列印SQL日誌最終解決方案

mybatis列印SQL日誌最終解決方案

問題

在程式除錯時想要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

。這兒把輸出調成了更低的trace,可以看到更詳細的資訊。