sen*_*nce 15 java log4j mybatis
我的项目是使用SpringMVC + Mybatis + EXTJS4设置的.这是我的配置:
# Rules reminder:
# DEBUG < INFO < WARN < ERROR < FATAL
# Global logging configuration
log4j.rootLogger=DEBUG,stdout
log4j.logger.org.apache.ibatis=DEBUG,stdout
log4j.logger.java.sql=DEBUG,stdout
#log4j.additivity.com.ibatis = false
#log4j.additivity.java.sql = false
## Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p %d %C: %m%n
Run Code Online (Sandbox Code Playgroud)
但是它不会在Console中打印SQL,任何人都可以帮助我吗?非常感谢
Ang*_*own 11
Jaradinor的答案可能会奏效.但是,我认为潜在的问题是由于MyBatis LogFactory类的实现方式.在静态块中,它尝试加载slf4j,然后加载commmons-logging,然后加载log4j.因此,如果您在类路径中有公共日志记录,它将使用它.由于您使用的是Spring,因此您可能拥有commons-logging.
这是因为像这样的问题我转移到了slf4j.用于slf4j-log4j12对log4j进行slf4j调用.用于jcl-over-slf4j将所有Spring(和其他)commons路由到slf4j(然后再到log4j).确保在执行此操作时从类路径中排除"真正的"commons-logging jar文件 - <exclude>如果您使用的是Maven ,则可以使用.
我遇到了类似的问题.以下代码帮助了我(我在mybatis类配置中使用它):
org.apache.ibatis.logging.LogFactory.useLog4JLogging();
Run Code Online (Sandbox Code Playgroud)
可能会导致问题成为类路径中的其他日志记录系统.
你需要把SLF4J-API-xxx.jar,SLF4J-log4j12-xxx.jar,log4j的环比SLF4J-xxx.jar,log4j的-xxx.jar(由版本替换XXX,例如1.6.3)在您的classpath并在你的src包中放入log4j.properties(见下文).
log4j.debug=true
log4j.rootCategory=DEBUG
## uncoment when run in production ##
#log4j.threshold=INFO
# logger error
log4j.logger.br.danilo.psc.exceptions=ERROR, psc-error
log4j.appender.psc-error = org.apache.log4j.RollingFileAppender
log4j.appender.psc-error.File=c:\\log-psc\\error\\log-error.log
log4j.appender.psc-error.MaxFileSize=1200KB
log4j.appender.psc-error.MaxBackupIndex=40
log4j.appender.psc-error.layout=org.apache.log4j.PatternLayout
log4j.appender.psc-error.layout.ConversionPattern=%d{dd/MM/yyyy HH:mm:ss,SSS} [%-5p] %m %n
# end logger error
# logger debug
log4j.logger.br.danilo.psc=DEBUG, psc-debug
log4j.appender.psc-debug = org.apache.log4j.ConsoleAppender
log4j.appender.psc-debug.layout=org.apache.log4j.PatternLayout
log4j.appender.psc-debug.layout.ConversionPattern=[%d{HH:mm:ss}] %-5p %c{3} %x - %m%n
# end logger debug
### mybatis loggers ###
log4j.logger.com.ibatis=DEBUG, psc-debug
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG, psc-debug
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG, psc-debug
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG, psc-debug
# sql loggers
log4j.logger.java.sql.Connection=DEBUG, psc-debug
log4j.logger.java.sql.Statement=DEBUG, psc-debug
log4j.logger.java.sql.PreparedStatement=DEBUG, psc-debug
log4j.logger.java.sql.ResultSet=DEBUG, psc-debug
Run Code Online (Sandbox Code Playgroud)
使用此.properties,您可以记录mybatis和sql中的所有步骤,例如打开连接,获取结果,关闭连接等.
干杯!