mybatis輸出SQL


1.導包

下載一個log4j-1.2.17.jar,放到WEB-INF的lib下,並加入build path

 

2.創建配置文件

在src下創建log4j.properties,填入以下內容:

log4j.rootLogger=DEBUG,Console
#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
log4j.logger.org.apache=INFO

log4j.logger.com.ibatis = ERROR 
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = ERROR 
log4j.logger.com.ibatis.common.jdbc.ScriptRunner = ERROR 
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = ERROR

log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG 
log4j.logger.java.sql.ResultSet=DEBUG

重點在於后面四句,至於前面的那些配置的作用,我還沒有徹底弄明白。

 

3.執行程序

此時可以發現控制台在每次執行數據庫操作時打印出了相應的SQL語句

 

如果需要在某些代碼段后面手動加入一些日志標記,也可以使用:

Logger logger = Logger.getLogger(當前類名.class);
//使用默認的配置信息,不需要寫log4j.properties
BasicConfigurator.configure();
//設置日志輸出級別為info,這將覆蓋配置文件中設置的級別
logger.setLevel(Level.INFO);
//下面的消息將被輸出
logger.info("this is an info");
logger.warn("this is a warn");
logger.error("this is an error");
logger.fatal("this is a fatal");


 

如果沒有調用BasicConfigurator.configure(),PropertyConfigurator.configure()或DOMConfigurator.configure()方法,Log4j會自動加載CLASSPATH下名為log4j.properties的配置文件。(所以上面的代碼沒有調用這個)

如果把此配置文件改為其他名字,例如my.properties,程序雖然仍能運行,但會報出不能正確初始化Log4j系統的提示。這時可以在程序中加上:

PropertyConfigurator.configure("classes/my.properties");


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM