亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis打印SQL語(yǔ)句的幾種常用方式

 更新時(shí)間:2023年11月15日 11:27:25   作者:yangzhihua  
當(dāng)我們動(dòng)態(tài)sql拼接的塊很多的時(shí)候,我們要想從*mapper.xml中直接找出完整的sql就會(huì)非常的難,這個(gè)時(shí)候經(jīng)常會(huì)需要把組合之后的完整SQL語(yǔ)句打印出來(lái),對(duì)調(diào)試非常有幫助的,所以本文小編給大家介紹了幾種Mybatis打印SQL語(yǔ)句的常用方式,需要的朋友可以參考下

在使用mybatis進(jìn)行開(kāi)發(fā)的時(shí)候,由于可以動(dòng)態(tài)拼接sql,這樣大大方便了我們。但是也有一定的問(wèn)題,當(dāng)我們動(dòng)態(tài)sql拼接的塊很多的時(shí)候,我們要想從*mapper.xml中直接找出完整的sql就會(huì)非常的難,這個(gè)時(shí)候經(jīng)常會(huì)需要把組合之后的完整SQL語(yǔ)句打印出來(lái),對(duì)調(diào)試非常有幫助的。

下面介紹幾種控制臺(tái)打印SQL語(yǔ)句的方式,并配上相應(yīng)示例:

  • 使用Log4j或其他日志框架來(lái)輸出SQL語(yǔ)句:

在Mybatis的配置文件中配置log4j或其他日志框架,然后配置輸出級(jí)別、輸出格式等。示例如下:

<configuration>
  <!-- 定義日志格式 -->
  <layout class="org.apache.log4j.PatternLayout">
    <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] %c{1}:%L - %m%n"/>
  </layout>
  
  <!-- 定義輸出級(jí)別 -->
  <root>
    <priority value="DEBUG"/>
    <appender-ref ref="STDOUT"/>
  </root>
</configuration>
  • 使用Mybatis提供的日志實(shí)現(xiàn)類org.apache.ibatis.logging.jdbc.BaseJdbcLogger來(lái)打印SQL語(yǔ)句:

實(shí)現(xiàn)Interceptor接口,在intercept方法中打印SQL語(yǔ)句。示例如下:

public class SqlLogInterceptor implements Interceptor {
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        Object[] args = invocation.getArgs();
 
        if (args != null && args.length > 1) {
            MappedStatement mappedStatement = (MappedStatement) args[0];
            Object parameter = args[1];
            BoundSql boundSql = mappedStatement.getBoundSql(parameter);
 
            String sql = boundSql.getSql();
            System.out.println("SQL語(yǔ)句:" + sql);
        }
 
        return invocation.proceed();
    }
}
  • 在Mybatis的配置文件中添加debug標(biāo)簽:

在Mybatis的配置文件中添加debug標(biāo)簽,設(shè)置為true即可打印SQL語(yǔ)句和參數(shù)信息,同時(shí)也會(huì)輸出相關(guān)的結(jié)果集信息。示例如下:

<configuration>
  <!-- 將debug設(shè)置為true -->
  <settings>
    <setting name="debug" value="true"/>
  </settings>
</configuration>
  • 使用Mybatis提供的參數(shù)緩存功能:

在Mybatis的配置文件中配置parameterMap標(biāo)簽,配合loggingLevel和cacheEnabled屬性即可打印相關(guān)日志信息,示例如下:

<configuration>
  <cacheEnabled>true</cacheEnabled>
  <parameterMap id="ParamMap" type="map">
    <parameter property="id" jdbcType="INTEGER"/>
  </parameterMap>
  
  <!-- 設(shè)置loggingLevel為TRACE -->
  <settings>
    <setting name="logImpl" value="LOG4J"/>
    <setting name="jdbcTypeForNull" value="NULL"/>
    <setting name="cacheEnabled" value="true"/>
    <setting name="loggingLevel" value="TRACE"/>
  </settings>
</configuration>

以上就是幾種控制臺(tái)打印SQL語(yǔ)句的方式及相應(yīng)示例。選擇適合自己的方式,會(huì)幫助我們更好地進(jìn)行數(shù)據(jù)庫(kù)調(diào)試和優(yōu)化。

到此這篇關(guān)于Mybatis打印SQL語(yǔ)句的幾種常用方式的文章就介紹到這了,更多相關(guān)Mybatis打印SQL語(yǔ)句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis plus條件構(gòu)造器queryWrapper、updateWrapper

    mybatis plus條件構(gòu)造器queryWrapper、updateWrapper

    這篇文章主要介紹了mybatis plus條件構(gòu)造器queryWrapper、updateWrapper,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 一文詳解Spring任務(wù)執(zhí)行和調(diào)度(小結(jié))

    一文詳解Spring任務(wù)執(zhí)行和調(diào)度(小結(jié))

    這篇文章主要介紹了一文詳解Spring任務(wù)執(zhí)行和調(diào)度(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Java中的設(shè)計(jì)模式與7大原則歸納整理

    Java中的設(shè)計(jì)模式與7大原則歸納整理

    本篇文章主要對(duì)Java中的設(shè)計(jì)模式如,創(chuàng)建型模式、結(jié)構(gòu)型模式和行為型模式以及7大原則進(jìn)行了歸納整理,需要的朋友可以參考下
    2017-04-04
  • 使用Spring?Batch實(shí)現(xiàn)大數(shù)據(jù)處理的操作方法

    使用Spring?Batch實(shí)現(xiàn)大數(shù)據(jù)處理的操作方法

    通過(guò)使用Spring?Batch,我們可以高效地處理大規(guī)模數(shù)據(jù),本文介紹了如何配置和實(shí)現(xiàn)一個(gè)基本的Spring?Batch作業(yè),包括讀取數(shù)據(jù)、處理數(shù)據(jù)和寫入數(shù)據(jù)的全過(guò)程,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • Java?中的泛型超全詳解

    Java?中的泛型超全詳解

    這篇文章主要介紹了泛型的概念、使用場(chǎng)景、泛型類、泛型方法、泛型接口、類型擦除以及泛型通配符,泛型是一種強(qiáng)大的工具,可以幫助我們編寫更安全和更通用的代碼,感興趣的朋友一起看看吧
    2025-03-03
  • 容器環(huán)境的JVM內(nèi)存設(shè)置實(shí)踐記錄

    容器環(huán)境的JVM內(nèi)存設(shè)置實(shí)踐記錄

    Docker和K8S的興起,很多服務(wù)已經(jīng)運(yùn)行在容器環(huán)境,對(duì)于java程序,JVM設(shè)置是一個(gè)重要的環(huán)節(jié),這里總結(jié)下我們項(xiàng)目里的最佳實(shí)踐,對(duì)容器環(huán)境的JVM內(nèi)存相關(guān)知識(shí)感興趣的朋友一起看看吧
    2022-03-03
  • java開(kāi)發(fā)之Jdbc分頁(yè)源碼詳解

    java開(kāi)發(fā)之Jdbc分頁(yè)源碼詳解

    這篇文章主要介紹了java開(kāi)發(fā)之Jdb分頁(yè)源碼詳解,需要的朋友可以參考下
    2020-02-02
  • java啟動(dòng)參數(shù)之謎的排查過(guò)程

    java啟動(dòng)參數(shù)之謎的排查過(guò)程

    在日常操作中,相信很多人對(duì)Java啟動(dòng)參數(shù)存在疑惑,下面這篇文章主要給大家介紹了關(guān)于java啟動(dòng)參數(shù)之謎的排查過(guò)程,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • 解決使用ProcessBuilder踩到的坑及注意事項(xiàng)

    解決使用ProcessBuilder踩到的坑及注意事項(xiàng)

    這篇文章主要介紹了解決使用ProcessBuilder踩到的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • java EasyExcel面向Excel文檔讀寫邏輯示例詳解

    java EasyExcel面向Excel文檔讀寫邏輯示例詳解

    這篇文章主要為大家介紹了java EasyExcel面向Excel文檔讀寫邏輯示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07

最新評(píng)論