参考文献:一:http://blog.csdn.net/rangqiwei/article/details/50825090

     二:http://www.mybatis.org/mybatis-3/zh/logging.html

要求:打印出数据库的sql语句日志

这里要强调的是,这里的数据库配置是直接放在了spring-mybatis.xml中,所以mybatis-config.xml是为了打印数据库日志单独加的

下面是mybatis-config.xml的内容:

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

下面是spring-mybatis.xml的内容:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="
  3. http://www.springframework.org/schema/beans
  4. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  5. http://www.springframework.org/schema/tx
  6. http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
  7. http://www.springframework.org/schema/aop
  8. http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
  9. http://www.springframework.org/schema/context
  10. http://www.springframework.org/schema/context/spring-context-4.1.xsd
  11. ">
  12.  
  13. <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
  14. <!-- 用户名-->
  15. <property name="user" value="${jdbc.username}"/>
  16. <!-- 用户密码-->
  17. <property name="password" value="${jdbc.password}"/>
  18. <property name="driverClass" value="${jdbc.driver_class}"/>
  19. <property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
  20.  
  21. <!--连接池中保留的最大连接数。默认值: 15 -->
  22. <property name="maxPoolSize" value="20"/>
  23. <!-- 连接池中保留的最小连接数,默认为:3-->
  24. <property name="minPoolSize" value="2"/>
  25. <!-- 初始化连接池中的连接数,取值应在minPoolSize与maxPoolSize之间,默认为3-->
  26. <property name="initialPoolSize" value="2"/>
  27.  
  28. <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。默认值: 0 -->
  29. <property name="maxIdleTime" value="60"/>
  30.  
  31. <!-- 当连接池连接耗尽时,客户端调用getConnection()后等待获取新连接的时间,超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。默认: 0 -->
  32. <property name="checkoutTimeout" value="3000"/>
  33.  
  34. <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。默认值: 3 -->
  35. <property name="acquireIncrement" value="2"/>
  36.  
  37. <!--定义在从数据库获取新连接失败后重复尝试的次数。默认值: 30 ;小于等于0表示无限次-->
  38. <property name="acquireRetryAttempts" value="0"/>
  39.  
  40. <!--重新尝试的时间间隔,默认为:1000毫秒-->
  41. <property name="acquireRetryDelay" value="1000" />
  42.  
  43. <!--关闭连接时,是否提交未提交的事务,默认为false,即关闭连接,回滚未提交的事务 -->
  44. <property name="autoCommitOnClose" value="false"/>
  45.  
  46. <!--如果为false,则获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常,但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。默认: false-->
  47. <property name="breakAfterAcquireFailure" value="false"/>
  48.  
  49. <!--每60秒检查所有连接池中的空闲连接。默认值: 0,不检查 -->
  50. <property name="idleConnectionTestPeriod" value="60"/>
  51. <!--c3p0全局的PreparedStatements缓存的大小。如果maxStatements与maxStatementsPerConnection均为0,则缓存不生效,只要有一个不为0,则语句的缓存就能生效。如果默认值: 0-->
  52. <property name="maxStatements" value="100"/>
  53. <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。默认值: 0 -->
  54. <property name="maxStatementsPerConnection" value="0"/>
  55. </bean>
  56.  
  57. <!--配置sqlSessionFactory 并读取mybatis的一些配置-->
  58. <bean name = "sqlSessionFactory" class = "org.mybatis.spring.SqlSessionFactoryBean">
  59.   <property name = "dataSource" ref = "dataSource"></property>
  60.   <property name="configLocation" value="classpath:mybatis-config.xml"></property><!-- 配置mybatis的日志记录 -->
  61.    <property name="mapperLocations" value="classpath:com/quicksure/mobile/mapping/*.xml"/>
  62. </bean>
  63.  
  64. <!--
  65. 自动扫描 将Mapper接口生成代理注入到Spring
  66. -->
  67. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  68.     <property name="basePackage" value="com.quicksure.mobile.dao" />
  69.     <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
  70.   </bean>
  71.  
  72. <!--
  73. 配置事物
  74. -->
  75. <bean id = "transactionManager" class = "org.springframework.jdbc.datasource.DataSourceTransactionManager">
  76.   <property name = "dataSource" ref = "dataSource"></property>
  77. </bean>
  78.  
  79. <!--
  80. <tx:annotation-driven transaction-manager = "transactionManager"/>
  81. -->
  82.  
  83. <!--
  84. 事物的具体内容
  85. -->
  86. <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
  87. <tx:attributes>
  88. <tx:method name="add*" propagation="REQUIRED" />
  89. <tx:method name="insert*" propagation="REQUIRED" />
  90. <tx:method name="save*" propagation="REQUIRED" />
  91. <tx:method name="update*" propagation="REQUIRED" />
  92. <tx:method name="modify*" propagation="REQUIRED" />
  93. <tx:method name="edit*" propagation="REQUIRED" />
  94. <tx:method name="delete*" propagation="REQUIRED" />
  95. <tx:method name="remove*" propagation="REQUIRED" />
  96. <tx:method name="get*" propagation="SUPPORTS" />
  97. <tx:method name="find*" propagation="SUPPORTS" />
  98. <tx:method name="load*" propagation="SUPPORTS" />
  99. <tx:method name="search*" propagation="SUPPORTS" />
  100. </tx:attributes>
  101. </tx:advice>
  102.  
  103. <!--
  104. 定义一个切面,在定义的切面上加入事物
  105. -->
  106.   <aop:config>
  107.     <aop:pointcut id="transactionPointcut" expression="execution(* com.quicksure.mobile.dms*.*.*(..))" />
  108.     <aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />
  109.   </aop:config>
  110. </beans>

下面是log4j.properties内容:

  1. ### set log levels ###
  2. log4j.rootLogger = INFO , C , D , E
  3.  
  4. # MyBatis logging configuration...
  5. log4j.logger.com.quicksure.mobile.dao=DEBUG 上色部分是作用范围,具体详情请看链接二
  6.  
  7. ### console ###
  8. log4j.appender.C = org.apache.log4j.ConsoleAppender
  9. log4j.appender.C.Target = System.out
  10. log4j.appender.C.layout = org.apache.log4j.PatternLayout
  11. log4j.appender.C.layout.ConversionPattern = [quicksureMobile][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n
  12.  
  13. ### log file ###
  14. log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
  15. log4j.appender.D.File = ../logs/quickSureMobileServer.log
  16. log4j.appender.D.Append = true
  17. log4j.appender.D.Threshold = INFO
  18. log4j.appender.D.layout = org.apache.log4j.PatternLayout
  19. log4j.appender.D.layout.ConversionPattern = [quicksureMobile][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n
  20.  
  21. ### exception ###
  22. log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
  23. log4j.appender.E.File = ../logs/quickSureMobileServerError.log
  24. log4j.appender.E.Append = true
  25. log4j.appender.E.Threshold = ERROR
  26. log4j.appender.E.layout = org.apache.log4j.PatternLayout
  27. log4j.appender.E.layout.ConversionPattern =[quicksureMobile][%p] [%-d{yyyy-MM-dd HH\:mm\:ss}] %C.%M(%L) | %m%n

log4j+mybatis打印数据库日志的更多相关文章

  1. 【他山之石】mybatis打印sql日志 相关配置

    背景:mybatis的sql日志打印对我来说一直比较迷,哪怕看过网上很多博客后还是这样,这两天刚好又遇到了问题,要查sql不得已又来查阅,这次终于搞定了. mybatis是有提供日志功能支持的,目前支 ...

  2. SpringBoot中Mybatis打印sql日志

    application.yml中加上 # springBoot+Mybatis 控制台打印SQL语句 (方式一) logging: level: com.zoctan.api.mapper : deb ...

  3. mybatis打印SQL日志

    在配置的log4j输出时,不能打印SQL信息,在mybatis-config.xml中添加如下配置即可 <settings> <setting name="logImpl& ...

  4. mybatis打印sql日志配置

    <settings> <!-- 打印查询语句 --> <setting name="logImpl" value="STDOUT_LOGGI ...

  5. log4j、使用log4j、打印sql日志

    添加pom文件依赖 <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifa ...

  6. django设置打印数据库日志

    在settings.py中添加: LOGGING = { 'disable_existing_loggers': False, 'version': 1, 'handlers': { 'console ...

  7. Springboot项目启动不了。也不打印任何日志信息。

    Springboot项目启动不了.也不打印任何日志信息. <!-- 在创建Spring Boot工程时,我们引入了spring-boot-starter,其中包含了spring-boot-sta ...

  8. mybatis结合log4j打印SQL日志

    mybatis结合log4j打印SQL日志 1.Maven引用jar包 默认的mybatis不能打印出SQL日志,不便于查看调试,须要结合log4jdbc-log4j2就能够完整的输入SQL的调试信息 ...

  9. 保存 Mybatis打印的SQL日志到数据库

    之前做项目,一般会有一张,用户操作记录的数据表,里面主要包括一些,用户请求的URL和请求参数,用以记录用户做过哪些事情.并没有以文件的形式来做记录,当然只适合于一些用户量特别少的系统. 而Mybati ...

随机推荐

  1. 在数据库访问项目中使用微软企业库Enterprise Library,实现多种数据库的支持

    在我们开发很多项目中,数据访问都是必不可少的,有的需要访问Oracle.SQLServer.Mysql这些常规的数据库,也有可能访问SQLite.Access,或者一些我们可能不常用的PostgreS ...

  2. 用JavaScript来实现链表LinkedList

    本文版权归博客园和作者本人共同所有,转载和爬虫请注明原文地址. 写在前面 好多做web开发的朋友,在学习数据结构和算法时可能比较讨厌C和C++,上学的时候写过的也忘得差不多了,更别提没写过的了.但幸运 ...

  3. 设计模式(九)装饰者模式(Decorator Pattern)

    一.引言 在软件开发中,我们经常想要对一类对象添加不同的功能,例如要给手机添加贴膜,手机挂件,手机外壳等,如果此时利用继承来实现的话,就需要定义无数的类,如StickerPhone(贴膜是手机类).A ...

  4. C#开发微信门户及应用(12)-使用语音处理

    我们知道,微信最开始就是做语音聊天而使得其更加流行的,因此语音的识别处理自然也就成为微信交流的一个重要途径,微信的开发接口,也提供了对语音的消息请求处理.本文主要介绍如何利用语音的识别,对C#开发的微 ...

  5. wampserver服务器无法启动(图标颜色不对)

    1.服务器一直无法启动,图标颜色一直显示黄色,并且不可用. 2.解决办法: (1) C:\wamp\bin\apache\apache2.4.9\bin ->httpd.exe  找到该文件 ( ...

  6. 口碑外卖系统架构图(li)

  7. maven之一:maven安装和eclipse集成

    maven作为一个项目构建工具,在开发的过程中很受欢迎,可以帮助管理项目中的bao依赖问题,另外它的很多功能都极大的减少了开发的难度,下面来介绍maven的安装及与eclipse的集成. maven的 ...

  8. git 管理

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 16.0px "Helvetica Neue"; color: #3e3e3e; bac ...

  9. 《HTML5》 Audio/Video全解

    一.标签解读 <audio> 标签属性 <audio id="media" src="http://www.abc.com/test.mp3" ...

  10. JavaScript Array数组方法详解

    Array类型是ECMAScript中最常用的引用类型.ECMAScript中的数据与其它大多数语言中的数组有着相当大的区别.虽然ECMAScript中的数据与其它语言中的数组一样都是数据的有序列表, ...