项目应用了IBATIS,如何才能让后台打印出SQL

时间:2022-06-20 21:42:00
查找的资料说是使用log4j来打印,但是添加了个文件,还是不能显示sql日志,请问大侠们是什么原因?
文件内容是这样的:
log4j.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>

<appender name="console" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%p] %d{yyyy-MM-dd HH:mm:ss} %l: %m%n" />
</layout>
</appender>

<appender name="rootLogger" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="../logs/rootLogger.log" />
<param name="Append" value="true" />
<param name="DatePattern" value="'.'yyyy-MM-dd" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%p] %d{yyyy-MM-dd HH:mm:ss} %l: %m%n" />
</layout>
</appender>

<logger name="com.bonc" additivity="false">
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="sam" additivity="false">
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="com.mchange" additivity="false">
<level value="error" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="org.springframework" additivity="false">
<level value="error" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="com.opensymphony.xwork2" additivity="false">
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="org.apache.struts2" additivity="false">
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="com.ibatis.common.logging" additivity="false">
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</logger>

<logger name="com.ibatis" additivity="true">
<level value="warn" />
</logger>

<logger name="java.sql.Connection" additivity="true">
<level value="warn" />
</logger>

<logger name="java.sql.Statement" additivity="true">
<level value="warn" />
</logger>

<root>
<level value="warn" />
<appender-ref ref="console" />
<appender-ref ref="rootLogger" />
</root>

</log4j:configuration>

6 个解决方案

#1


#ibatis logger config
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

#2


引用 1 楼 xiaoye2892 的回复:
#ibatis logger config
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.sqlma……

你好,这个也是写到log4j文件里的么?

#3


一般都写在log4j.properties文件中的

#4


那这个log4j文件要在其他的什么文件进行配置么?
还是直接放到src下编译一下就可以用了呢?

#5


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能够打出sql语句。
如果放在src下编译下就可以了,如果放在web-inf下则可以通过

<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/conf/log/log4j.xml</param-value>
</context-param>

<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
即可。

#6


引用 5 楼 liujun822 的回复:
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.SqlMapCli……

呵呵 搞定了 非常感谢!!!

#1


#ibatis logger config
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

#2


引用 1 楼 xiaoye2892 的回复:
#ibatis logger config
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.sqlma……

你好,这个也是写到log4j文件里的么?

#3


一般都写在log4j.properties文件中的

#4


那这个log4j文件要在其他的什么文件进行配置么?
还是直接放到src下编译一下就可以用了呢?

#5


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能够打出sql语句。
如果放在src下编译下就可以了,如果放在web-inf下则可以通过

<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/conf/log/log4j.xml</param-value>
</context-param>

<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
即可。

#6


引用 5 楼 liujun822 的回复:
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.SqlMapCli……

呵呵 搞定了 非常感谢!!!