我的项目是使用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
但它不会在Console中打印SQL,任何人都可以帮助我吗?非常感谢
答案 0 :(得分:10)
Jaradinor的回答可能会奏效。但是,我认为潜在的问题是由于MyBatis LogFactory类的实现方式。在静态块中,它尝试加载slf4j,然后加载commmons-logging,然后加载log4j。因此,如果您在类路径中有公共日志记录,它将使用它。由于您使用的是Spring,因此您可能会进行公共日志记录。
这是因为像这样的问题我转移到了slf4j。使用slf4j-log4j12
让slf4j调用log4j。使用jcl-over-slf4j
将所有Spring(和其他)commons路由到slf4j(然后再到log4j)。确保在执行此操作时从类路径中排除“真正的”commons-logging jar文件 - 如果使用Maven,可以使用<exclude>
。
答案 1 :(得分:8)
我遇到了类似的问题。以下代码对我有所帮助 (我在mybatis类配置中使用过它):
org.apache.ibatis.logging.LogFactory.useLog4JLogging();
可能导致问题成为您的其他日志系统 类路径。
答案 2 :(得分:5)
你需要把slf4j-api-xxx.jar,slf4j-log4j12-xxx.jar,log4j-over-slf4j-xxx.jar,log4j-xxx.jar(用版本替换xxx,例如1.6.3 )在你的类路径和你的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
使用此.properties,您可以记录mybatis和sql中的所有步骤,例如打开连接,获取结果,关闭连接等。
喝彩!