MyBatis自定義Plugin

来源:https://www.cnblogs.com/lhl5230/archive/2018/05/31/9119601.html
-Advertisement-
Play Games

作用 官方說明: MyBatis 允許你在已映射語句執行過程中的某一點進行攔截調用。 什麼意思呢?就是你可以對執行某些方法之前進行攔截,做自己的一些操作,如: 1.記錄所有執行的SQL(通過對 MyBatis org.apache.ibatis.executor.statement.Statemen ...


作用

官方說明:

MyBatis 允許你在已映射語句執行過程中的某一點進行攔截調用。

什麼意思呢?就是你可以對執行某些方法之前進行攔截,做自己的一些操作,如:

1.記錄所有執行的SQL(通過對 MyBatis org.apache.ibatis.executor.statement.StatementHandler 中的prepare 方法進行攔截)

2.修改SQL(org.apache.ibatis.executor.Executor中query方法進行攔截)等。

但攔截的方法調用有限制,MyBatis 允許使用插件來攔截的方法調用包括:

  • Executor (update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)
  • ParameterHandler (getParameterObject, setParameters)
  • ResultSetHandler (handleResultSets, handleOutputParameters)
  • StatementHandler (prepare, parameterize, batch, update, query)

實現

使用插件是非常簡單的,只需實現 Interceptor 介面,並指定想要攔截的方法簽名即可。

// ExamplePlugin.java
@Intercepts({@Signature(
  type= Executor.class,
  method = "update",
  args = {MappedStatement.class,Object.class},
  @Signature(
   type = Executor.class, //必須為上面所支持的類
    method = "query", //類中支持的方法,可從源碼中查看支持哪些方法
    args = {MappedStatement.class, Object.class , RowBounds.class, ResultHandler.class})}) //對應的參數Class,也可從源碼中查看
public class ExamplePlugin implements Interceptor {
  public Object intercept(Invocation invocation) throws Throwable {
  Object[] queryArgs = invocation.getArgs();
    MappedStatement mappedStatement = (MappedStatement) queryArgs[0];
    Object parameter = queryArgs[1];
    BoundSql boundSql = mappedStatement.getBoundSql(parameter);
    String sql = boundSql.getSql();//獲取到SQL ,可以進行調整
    String name = invocation.getMethod().getName();
    queryArgs[1] = 2; //可以修改參數內容
    System.err.println("攔截的方法名是:" + name);
    return invocation.proceed();
  }
  public Object plugin(Object target) {
    return Plugin.wrap(target, this);
  }
  public void setProperties(Properties properties) {
  }
}

 

在配置文件中註冊插件

<!-- mybatis-config.xml -->
<plugins>
  <plugin interceptor="org.mybatis.example.ExamplePlugin">
    <property name="someProperty" value="100"/>
  </plugin>
</plugins>

當我們調用query方法時,匹配攔截器的方法, 所以會執行攔截器下intercept方法,做自己的處理。

參考資料,官網

http://www.mybatis.org/mybatis-3/zh/configuration.html#plugins

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Spring Cloud是一系列框架的有序集合。利用Spring Boot的開發模式簡化了分散式系統基礎設施的開發,都可以用Spring Boot的開發風格做到一鍵啟動和部署。Spring Cloud將目前比較成熟、經得起實際考驗的服務框架組合起來,通過Spring Boot風格進行再封裝,屏蔽掉了 ...
  • 長期更新IT編程視頻教程,資料收集整理不易,需要一點費用 有意者加QQ:2773400,非誠勿擾! 長期更新IT編程視頻教程,資料收集整理不易,需要一點費用 有意者加QQ:2773400,非誠勿擾! ...
  • Java併發編程,你需要知道的 併發編程三要素 原子性 原子,即一個不可再被分割的顆粒。在Java中原子性指的是一個或多個操作要麼全部執行成功要麼全部執行失敗。 有序性 程式執行的順序按照代碼的先後順序執行。(處理器可能會對指令進行重排序) 可見性 當多個線程訪問同一個變數時,如果其中一個線程對其作 ...
  • 由面向對象的思想引入面向對象的設計,最後面向對象編程。 類的練習: 類的練習二: 老師http://www.cnblogs.com/linhaifeng/articles/6182264.html ...
  • 在我們給外部提供的API中,可會存在多個版本,不同的版本可能對應的功能不同,所以這時候版本使用就顯得尤為重要,django rest framework也為我們提供了多種版本使用方法。 版本使用方式: 1.在url中傳遞版本:如http://www.example.com/api?version=v ...
  • (一) 冒泡排序 冒泡排序的作用就是反覆交換相鄰未按次序排列的數據。 看下麵這張圖,不難發現,第二重for迴圈每一輪迴圈結束後都會排好一個數據 第一輪結束後是:[8, 7, 3, 1, 11],不難發現,11是排序好了的,所以第二輪的迴圈次數在這次的基礎上-1就行了,即len(data)-1-i 第 ...
  • 什麼是數組:就是一堆相同類型的數據放一堆(一組相關變數的集合) 定義語法: 數據類型 數組名[] = new 數據類型[長度]; 聲明數組:數據類型 數組名 [] = null; 開闢數組:數組名 = new 數據類型[長度]; 記憶體分析: 2.分佈完成 數組記憶體引用 數組是一個引用數據類型 以上方 ...
  • 微服務自2014年3月由Martin Fowler首次提出以來,在Spring Cloud、Dubbo等各類微服務框架的幫助下,以燎原之勢席卷了整個IT技術界,成為了最主流的分散式應用解決方案。但仍然還有很多問題沒有得到根本性的解決,比如技術門檻高、多語言支持不足、代碼侵入性強等。如何應對這些挑戰成 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...