ibatis生成sql
㈠ mybatis怎麼輸出sql語句
#將ibatis log4j運行級別調到DEBUG可以在控制台列印出ibatis運行的sql語句
log4j.rootLogger=debug,stdout,logfile
### 把日誌信息輸出到控制台 ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#log4j.appender.stdout.Target=System.err
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
### 把日誌信息輸出到文件:jbit.log ###
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=D:/test.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %F %p %m%n
###顯示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
㈡ ibatis配置文件中update語句的寫法
ibatis標簽提供生成sql的功能,沒有標簽滿足你的需求。
但是可以從sql的角度解決,像是你用select的時候的1=1的處理方式。
我是這么搞的
update user
set id = id
<............>
where id = #{id}
㈢ Ibatis如何列印SQL語句
方法:
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
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,stdout
把這段配置放到log4j.properties文件中即可。
在項目試運行需要維護得階段可以把debug改為error,這樣伺服器後台只列印報錯信息,這樣既可以看清錯誤又可以減輕伺服器負擔(後台不斷列印數據很消耗伺服器資源的)
㈣ mybatis怎麼列印出sql,我被誤導了很多年
探討MyBatis列印SQL語句的方法,常見答案建議將java.sql.*,com.ibatis的日誌級別配置為debug以實現實現。但實際操作中發現,列印SQL與上述Java框架並無直接關聯。MyBatis使用的日誌對象是org.apache.ibatis.logging.slf4j.Slf4jImpl(statementLog)。日誌的列印與否取決於statementLog與log4j.xml或log4j.properties中log4j.logger的匹配情況。
詳細分析如下:
1. 核心在於statementLog的調試級別,決定是否列印SQL。
具體實現於org.apache.ibatis.executor.SimpleExecutor,當調用ConnectionLogger對象時,便執行列印日誌的代碼。
關鍵代碼行位於org.apache.ibatis.logging.jdbc.BaseJdbcLogger的ConnectionLogger(BaseJdbcLogger).debug(String, boolean)處,位於第141行。
2. statementLog的注入來源於MappendStatement。
MappendStatement由org.apache.ibatis.session.Configuration注冊。查看MappendStatement的構造過程,LogFactory.getLog(xx)這行代碼是關鍵。
從這段代碼的值來看,是否使用與java.sql、com.ibatis框架無關的日誌框架。
MyBatis支持使用多種日誌框架,包括slf4j或common-logger,其兼容性足夠強大。
在類org.apache.ibatis.logging.LogFactory中,載入類時會執行靜態代碼塊,嘗試各種日誌框架實現。若成功,則實例化logConstructor,確保即使客戶端未包含特定實現,代碼也不會出錯。
總結而言,配置log4j.logger的值以指定的日誌級別,即可實現MyBatis列印SQL語句的目的。例如,配置log4j.logger.com.helijia.search=DEBUG。