mybatis 3.2.8 + log4j2.0.2 控制台输出sql语句

mybatis3.2.7有一个bug,使用log4j2 (2.0.2)版本时,会找不到类 ,导致启动失败,详见

https://github.com/mybatis/mybatis-3/issues/235

但没过多久 , 3.2.8就已经修复了这个bug , 最新的mybatis3.2.8下载地址为:

https://github.com/mybatis/mybatis-3/releases

mybatis 3.2.8 整合 log4j2.0.2并不复杂 , 如果用spring-mvc做为web框架 , 以下是使用步骤:

 

1. pom.xml添加依赖项

 1 <dependency>
 2             <groupId>org.slf4j</groupId>
 3             <artifactId>slf4j-api</artifactId>
 4             <version>1.7.7</version>
 5         </dependency>
 6         <dependency>
 7             <groupId>org.apache.logging.log4j</groupId>
 8             <artifactId>log4j-api</artifactId>
 9             <version>${log4j2.version}</version>
10         </dependency>
11         <dependency>
12             <groupId>org.apache.logging.log4j</groupId>
13             <artifactId>log4j-core</artifactId>
14             <version>${log4j2.version}</version>
15         </dependency>
16         <dependency>
17             <groupId>org.apache.logging.log4j</groupId>
18             <artifactId>log4j-web</artifactId>
19             <version>${log4j2.version}</version>
20         </dependency>
21         <dependency>
22             <groupId>org.apache.logging.log4j</groupId>
23             <artifactId>log4j-slf4j-impl</artifactId>
24             <version>2.0.2</version>
25         </dependency>

View Code

slf4j的二项好象不加也行 , 大家可以自行试试

 

2. web.xml中增加listener

 1     <listener>
 2         <listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>
 3     </listener>
 4     <filter>
 5         <filter-name>log4jServletFilter</filter-name>
 6         <filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class>
 7     </filter>
 8     <filter-mapping>
 9         <filter-name>log4jServletFilter</filter-name>
10         <url-pattern>/*</url-pattern>
11         <dispatcher>REQUEST</dispatcher>
12         <dispatcher>FORWARD</dispatcher>
13         <dispatcher>INCLUDE</dispatcher>
14         <dispatcher>ERROR</dispatcher>
15     </filter-mapping>

View Code

上面这一段,加在web.xml最开头(注:这一步好象也可以去掉)

 

3. maven项目的resouces目录下 , 放置log4j2.xml

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <Configuration status="off" monitorInterval="1800">
 3
 4     <Appenders>
 5         <Console name="Console" target="SYSTEM_OUT">
 6             <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
 7         </Console>
 8     </Appenders>
 9
10     <Loggers>
11         <Root level="debug">
12             <AppenderRef ref="Console" />
13         </Root>
14     </Loggers>
15 </Configuration>

View Code

只要把root logger的级别调成debug级别即可

 

4.如果采用mybatis-spring项目来集成mybatis, spring配置文件参考下面这样:

1     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
2         <property name="dataSource" ref="dataSource" />
3         <property name="configLocation" value="classpath:mybatis-config.xml"></property>
4         <property name="typeAliasesPackage" value="com.cnblogs.yjmyzz.entity"></property>
5         <property name="mapperLocations" value="classpath:mybatis/**/*.xml"></property>
6     </bean>

View Code

<property name="configLocation" value="classpath:mybatis-config.xml"></property> 这一行,指定了mybatis的主配置文件

 

5.mybatis-config配置文件

1 <?xml version="1.0" encoding="UTF-8" ?>
2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
3 "http://mybatis.org/dtd/mybatis-3-config.dtd">
4 <configuration>
5     <settings>
6         <setting name="logImpl" value="LOG4J2" />
7     </settings>
8 </configuration>

View Code

指定mybatis使用log4j2来记录日志

 

如果在jboss eap 6.x上部署 , 启动时会有一个error , 但并不影响项目正常运行 , 这是log4j2的一个bug , 估计在后续版本中会修复,详情见:http://mail-archives.apache.org/mod_mbox/logging-log4j-dev/201403.mbox/%3CJIRA.12696787.1393155172406.128647.1393632623629@arcas%3E 

 

鉴于国内不太方便下载github上的东西,最后给出mybatis-2.3.8.jar包文件下载:mybatis-3.2.8.jar.zip

时间: 2024-12-07 19:32:05

mybatis 3.2.8 + log4j2.0.2 控制台输出sql语句的相关文章

Mybatis控制台打印Sql语句的实现代码_java

MyBatis简介 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录. 下面看下Mybatis控制台打印Sql语句 1.首先将ibatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语

hibernateTemplate.update() 方法 控制台已输出SQL语句,但数据库没有更新

问题描述 运用Spring集成Hibernate使用hibernateTemplate.update()执行修改用户操作SQL语句控制台已经输出,对象参数也正确,控制台也没有输出事务回滚但数据库数据没有更新卡了一上午了,在网上查了相关问题没有找到合适答案,所以来CSDN求教求大神解答... 解决方案 解决方案二:@Transactional(propagation=Propagation.REQUIRED,isolation=Isolation.DEFAULT)publicvoidupdateS

[MyBatis]动态输出SQL语句

(1)使用日志来实现SQL语句的输出.添加log4j的jar包: (2)log4j文件的配置: log4j.rootLogger=DEBUG,Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=%d [%t

tomcat控制台输出信息时会卡住的原因

在window2003 系统下运行tomcat5.5 当运行时代码中有控制台输出的语句,如System.out.println 或 e.printStackTrace() 时,当前线程会卡住,而且控制台没有任何输出,只要在运行的服务器上敲下空格或回车,才回有输出,该线程才恢复运行. 原因: 1 在控制台左上角鼠标右键,选属性 2 看图上的解释,去掉那个快速编辑 3 这个你根据情况自己决定吧.我一般选下面那个

log4j2 0-用了log4j2,web项目中只有控制台输出,没有日志记录。tomcat7.0.59,谁知道什么原因

问题描述 用了log4j2,web项目中只有控制台输出,没有日志记录.tomcat7.0.59,谁知道什么原因 用了log4j2,web项目中只有控制台输出,没有日志记录.tomcat7.0.59,谁知道什么原因

mybatis3.0+spring3.1下,控制台打印sql问题。。大侠进。。

问题描述 刚开始用的是ibatis2.3.控制台打印sql毫无压力换了mybatis3.0后,控制台是空空如也,啥也没网上也找了各种说法,都不行,也不知道都是忽悠人的还是配置没对没办法,只能来csdn请教了,有哪位仁兄是用mybatis3.0+spring3.1架构,后台sql打印完好的请指点一二呗...不胜感激了...成功的分都给你拉...阿门 解决方案 解决方案二:没人么..解决方案三:真的没人知道吗..解决方案四:log4j.logger.com.ibatis=DEBUG解决方案五:<!-

图片-mybatis delete返回值为0

问题描述 mybatis delete返回值为0 解决方案 你那样写是把一个list的结果集当成了一个参数,执行delete是找不到对于的条件就没有删掉一条记录所有返回的结果为哦,像delete和update返回的结果int值代表着对多少条记录数据的操作, <delete id="batchDeleteStudent" parameterType="java.util.List"> DELETE FROM STUDENT WHERE buyer_id=#

用log4j打印mybatis 连接数据库SQL语句无法打印,用的是c3po连接池

问题描述 用log4j打印mybatis 连接数据库SQL语句无法打印,用的是c3po连接池 log4j配置如下: log4j.rootLogger=info, stdout,file log4j.logger.org.springframework=INFO log4j.logger.org.springframework=ERROR log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.lay

mybatis-求经验!Mybatis 针对Oracle数据库如何写“多条件”批量删除语句?

问题描述 求经验!Mybatis 针对Oracle数据库如何写"多条件"批量删除语句? 我的写法: <delete id="delMultiByIds2" parameterType="java.util.List"> delete from tb_duty where <foreach collection="list" item="item" index="index&quo