15

我的项目是用 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

但它不会在控制台中打印 SQL,任何人都可以帮助我吗?非常感谢

4

3 回答 3

11

Jaradinor 的回答可能会奏效。但是,我认为根本问题是由于 MyBatis LogFactory 类是如何实现的。在静态块中,它尝试加载 slf4j,然后是 commmons-logging,然后是 log4j。因此,如果您的类路径中有公共日志记录,它将使用它。由于您使用的是 Spring,因此您可能确实有 commons-logging。

正是因为这样的问题,我才转向 slf4j。用于slf4j-log4j12让 slf4j 调用 log4j。用于jcl-over-slf4j将所有 Spring(和其他)commons-logging 路由到 slf4j(然后到 log4j)。确保在执行此操作时从类路径中排除“真正的”commons-logging jar 文件 -<exclude>如果您使用的是 Maven,则可能需要。

于 2011-09-10T00:49:03.090 回答
9

我遇到了类似的问题。以下代码帮助了我(我在 mybatis 类配置中使用过):

org.apache.ibatis.logging.LogFactory.useLog4JLogging(); 

可能会导致问题成为您的类路径中的其他日志记录系统。

于 2011-09-09T06:31:18.610 回答
5

您需要在您的类路径并在您的 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 中记录所有步骤,例如打开连接、获取结果、关闭连接等。

干杯!

于 2011-10-28T10:26:45.680 回答