欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

spring?boot?mybatis日志輸出到控制臺(tái)的方法實(shí)踐

 更新時(shí)間:2024年05月05日 11:19:26   作者:mob6454cc76bc4a  
在開發(fā)過程中我們往往需要打印出SQL語句,這樣就方便我們監(jiān)控問題,本文主要介紹了spring?boot?mybatis日志輸出到控制臺(tái)的方法實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下

在開發(fā)過程中我們往往需要打印出SQL語句,這樣就方便我們監(jiān)控問題。下面我來簡(jiǎn)單的介紹一下我使用過的兩種方法,一種需要使用log4j,一種需要在MyBatis的配置文件里配置。

日志級(jí)別設(shè)置

日志記錄器(Logger)的行為是分等級(jí)的。分為: OFF FATAL WARN INFO DEBUG  TRACE  ALL ;

Log4j建議只使用四個(gè)級(jí)別,優(yōu)先級(jí)從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這里定義的級(jí)別,您可以控制到應(yīng)用程序中相應(yīng)級(jí)別的日志信息的開關(guān)。 比如在這里定義了INFO級(jí)別,則應(yīng)用程序中所有DEBUG級(jí)別的日志信息將不被打印出來。 程序會(huì)打印高于或等于所設(shè)置級(jí)別的日志,設(shè)置的日志等級(jí)越高,打印出來的日志就越少。 
如果設(shè)置級(jí)別為INFO,則優(yōu)先級(jí)高于等于INFO級(jí)別(如:INFO、WARN、 ERROR)的日志信息將可以被輸出,小于該級(jí)別的如DEBUG將不會(huì)被輸出。

第一種方法:

直接使用Log4j輸出SQL語句。這種方法比較簡(jiǎn)單,只需要在log4j的配置文件(log4j.properties)里面進(jìn)行配置,不需要進(jìn)行其他額外的配置,當(dāng)然,這里需要使用log4j的jar包,如果使用maven,那么在pom文件里面添加即可。

log4j.properties配置文件:

### 日志級(jí)別設(shè)置 ###  
log4j.rootLogger = INFO , C , D , E   
  
### 控制臺(tái)打印 ###  
log4j.appender.C = org.apache.log4j.ConsoleAppender  
log4j.appender.C.Target = System.out  
log4j.appender.C.layout = org.apache.log4j.PatternLayout  
log4j.appender.C.layout.ConversionPattern = [test][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n  
  
### 文件輸出 ###  
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.D.File = ../logs/test.log  
log4j.appender.D.Append = true  
log4j.appender.D.Threshold = INFO   
log4j.appender.D.layout = org.apache.log4j.PatternLayout  
log4j.appender.D.layout.ConversionPattern = [test][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n  
  
### exception ###  
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.E.File = ../logs/test_error.log   
log4j.appender.E.Append = true  
log4j.appender.E.Threshold = ERROR   
log4j.appender.E.layout = org.apache.log4j.PatternLayout  
log4j.appender.E.layout.ConversionPattern = [test][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n

下面這段是重點(diǎn)

###############Log4j 4 SQL Output start#################
log4j.logger.com.***.***.dao=DEBUG 
log4j.logger.com.springframework=DEBUG
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
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.org.apache.ibatis.logging.commons.JakartaCommonsLoggingImpl=DEBUG
log4j.logger.java.sql=DEBUG,CONSOLE
###############Log4j 4 SQL Output end###################

com.***.***.dao 是你的 Dao包所在的路徑

通過上面的配置后,即可在控制臺(tái)查看mybatis執(zhí)行的SQL語句。

第二種方法:

在mybatis配置文件的<settings>標(biāo)簽里面添加如下語句:

<setting name="logImpl" value="STDOUT_LOGGING" />

具體如:

<settings>
        <!-- 打印查詢語句  這種方式不需要進(jìn)行l(wèi)og4j配置 -->
       <setting name="logImpl" value="STDOUT_LOGGING" /> 
    </settings>

如果使用spring集成了mybatis,那么就直接在spring-mybatis文件里的mybatis配置標(biāo)簽里添加上面的語句即可。

如果配置文件里沒有<settings>標(biāo)簽,我們可以新建一個(gè)mybatis-config.xml文件,然后在spring-mybatis(spring集成mybatis的配置文件)里引入該文件即可,具體如下:

1. 新建的mybatis-config.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration   
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <settings>
        <!-- 打印查詢語句  這種方式不需要進(jìn)行l(wèi)og4j配置 -->
       <setting name="logImpl" value="STDOUT_LOGGING" /> 
    </settings>
</configuration>

2. spring-mybatis.xml中引入的mybatis-config.xml文件

<?xml version="1.0" encoding="UTF-8"?>  
<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"  
    xsi:schemaLocation="  
        http://www.springframework.org/schema/beans   
        http://www.springframework.org/schema/beans/spring-beans-4.1.xsd   
        http://www.springframework.org/schema/tx   
        http://www.springframework.org/schema/tx/spring-tx-4.1.xsd  
        http://www.springframework.org/schema/aop   
        http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
        ">  
 
    <!-- 配置數(shù)據(jù)源 使用的是Druid數(shù)據(jù)源 -->  
    <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource"  
        init-method="init" destroy-method="close">  
        <property name="url" value="${jdbc.url}" />  
        <property name="username" value="${jdbc.username}" />  
        <property name="password" value="${jdbc.password}" />  
  
        <!-- 初始化連接大小 -->  
        <property name="initialSize" value="0" />  
        <!-- 連接池最大使用連接數(shù)量 -->  
        <property name="maxActive" value="20" />  
          
        <!-- 連接池最小空閑 -->  
        <property name="minIdle" value="0" />  
        <!-- 獲取連接最大等待時(shí)間 -->  
        <property name="maxWait" value="60000" />  
        <property name="poolPreparedStatements" value="true" />  
        <property name="maxPoolPreparedStatementPerConnectionSize"  
            value="33" />  
        <!-- 用來檢測(cè)有效sql -->  
        <property name="validationQuery" value="${validationQuery}" />  
        <property name="testOnBorrow" value="false" />  
        <property name="testOnReturn" value="false" />  
        <property name="testWhileIdle" value="true" />  
        <!-- 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒 -->  
        <property name="timeBetweenEvictionRunsMillis" value="60000" />  
        <!-- 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒 -->  
        <property name="minEvictableIdleTimeMillis" value="25200000" />  
        <!-- 打開removeAbandoned功能 -->  
        <property name="removeAbandoned" value="true" />  
        <!-- 1800秒,也就是30分鐘 -->  
        <property name="removeAbandonedTimeout" value="1800" />  
        <!-- 關(guān)閉abanded連接時(shí)輸出錯(cuò)誤日志 -->  
        <property name="logAbandoned" value="true" />  
        <!-- 監(jiān)控?cái)?shù)據(jù)庫 -->  
        <property name="filters" value="mergeStat" />  
    </bean>  
  
    <!-- myBatis文件 -->  
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />
        
         <!-- 引入打印查詢語句的配置文件 -->
        <property name="configLocation" value="classpath:mybatis-config.xml"></property>

         
        <!-- 自動(dòng)掃描entity目錄, 省掉Configuration.xml里的手工配置 --> 
        <property name="mapperLocations" value="classpath:com/zhh/merchantwap/mapping/*.xml" /> 
         
            <!-- pageHelper 分頁插件 --> 
         <property name="plugins">
              <array>
               <bean class="com.github.pagehelper.PageHelper">
                <property name="properties">
                 <value>
                     dialect=Oracle
                 </value>
                </property>
               </bean>
              </array>
        </property>
    </bean>  
  
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
        <property name="basePackage" value="com.zhh.merchantwap.dao" />  
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />  
    </bean>  
  
    <!-- 配置事務(wù)管理器 -->  
    <bean id="transactionManager"  
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
        <property name="dataSource" ref="dataSource" />  
    </bean>  
  
    <!-- 注解方式配置事物 -->  
    <!-- <tx:annotation-driven transaction-manager="transactionManager" /> -->  
  
    <!-- 攔截器方式配置事物 -->  
    <tx:advice id="transactionAdvice" transaction-manager="transactionManager">  
        <tx:attributes>  
            <tx:method name="insert*" propagation="REQUIRED" />  
            <tx:method name="update*" propagation="REQUIRED" />  
            <tx:method name="delete*" propagation="REQUIRED" />   
            <tx:method name="get*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="find*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="select*" propagation="SUPPORTS" read-only="true" />  
  
        </tx:attributes>  
    </tx:advice>  
    <!-- Spring aop事務(wù)管理 -->  
    <aop:config>  
        <aop:pointcut id="transactionPointcut"  
            expression="execution(* com.zhh.merchantwap.service..*Impl.*(..))" />  
        <aop:advisor pointcut-ref="transactionPointcut"  
            advice-ref="transactionAdvice" />  
    </aop:config>  
  
</beans>

引入的標(biāo)簽:<property name="configLocation" value="classpath:mybatis-config.xml"></property> 

通過上面的配置,我們就可以在控制臺(tái)查看執(zhí)行的SQL語句了。

因?yàn)槊總€(gè)項(xiàng)目的配置文件都不太一樣,所以具體配置標(biāo)簽所在的位置得根據(jù)情況來定。

到此這篇關(guān)于spring boot mybatis日志輸出到控制臺(tái)的方法實(shí)踐的文章就介紹到這了,更多相關(guān)spring boot mybatis日志輸出內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論