MP 启动注入 SQL 原理分析
生活随笔
收集整理的這篇文章主要介紹了
MP 启动注入 SQL 原理分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
MP 啟動注入 SQL 原理分析
文章目錄
- 一、MybatisPlus需要sql語句嗎?
- 解答:需要
- 1.1. 問題:為什么MybatisPlus看不到sql語句?
- 1.2. 分析:繼承關系
- 1.3. 假設:操作數據庫一定有sql
- 二、通過現象看本質
- 2.1. 測試案例
- 2.2. debug調試運行
- 2.2.1. employeeMapper的本質
- 2.2.2. MapperProxy中的對象
- 2.2.3. sqlSessionFactory中的對象
- 2.2.4. configuration對象
- 2.2.5. 方法對應關系
- 2.2.6. MP在啟動的時候
- 2.2.7. 當我們調用方法的時候
- 三、源碼分析:
- 3.1. 根據方法找到類
- 3.2 斷點調試
- 3.3. 接著調用addDeleteMappedStatement
- 3.4. 調用injectDeleteByIdSql
- 3.5. sqlSource拼接完成
- 3.5. sqlSource拼接完成,繼續調用刪除方法
一、MybatisPlus需要sql語句嗎?
解答:需要
1.1. 問題:為什么MybatisPlus看不到sql語句?
1.2. 分析:繼承關系
- xxxMapper繼承了BaseMapper,BaseMapper提供了通用的CRUD方法,
1.3. 假設:操作數據庫一定有sql
- 方法來源于BaseMapper,有方法就必須有SQL,因為Mybatis最終還是需要通過SQL語句里操作數據庫。
二、通過現象看本質
2.1. 測試案例
@Testpublic void testCommonSelect() {//1. 根據主鍵ID查詢Integer idPK = 1;Employee employee = employeeMapper.selectById(idPK);System.out.println(employee);}2.2. debug調試運行
employeeMapper就是一個接口,但是我們拿到的對象是一個代理對象,這個JDK動態代理
2.2.1. employeeMapper的本質
- 就是org.apache.ibatis.binding.MapperProxy@4362d7df
2.2.2. MapperProxy中的對象
- MapperProxy中sqlSeaaion有一個sqlSessionFactory
2.2.3. sqlSessionFactory中的對象
- 在sqlSessionFactory中有一個重要的對象configuration
2.2.4. configuration對象
- 這個對象是mybatis的全局配置對象,它包含了所有的配置信息。
- 在configuration里面有一個mappendStatements對象,它里面每一個都是一個mappendStatement
其實,每一個都是一個mapperdStatement都表示Mapper接口的一個方法與Mapper映射文件中的一個sql語句。
2.2.5. 方法對應關系
- 在BaseMapper定義的每一個方法,都會有一條sql語句與之對應mapperdStatement。
2.2.6. MP在啟動的時候
- 就會分析已經把我們BaseMapper里面的每一個方法,,將來索要執行的sql語句,都幫我們構造好了,并且都幫我們都保存到了configuraion里面的MappedStatements中的MappedStatement了。
2.2.7. 當我們調用方法的時候
- 它就會回到configuration里面找到我們的MappedStatements,然后根據調用方法的名字,再去找到對應的sql語句,在其執行。
本質
在控制臺,在實例化employeeMapper這個bean的時候,都調用了addMappedStatement這個方法,來添加一個addMappedStatement,而每一個addMappedStatement對應著mapper文件中的每一個方法
三、源碼分析:
3.1. 根據方法找到類
根據addMappedStatement,找到此方法的類AutoSqlInjector SQL 自動注入器,
這個java文件
這個.class文件
3.2 斷點調試
- 在.class文件中的addMappedStatement方法上打斷點,dubug運行,當F8走到此方時,參數包括sqlSource 等都是前面傳過來的,因此,我們需要往前推
3.3. 接著調用addDeleteMappedStatement
3.4. 調用injectDeleteByIdSql
3.5. sqlSource拼接完成
3.5. sqlSource拼接完成,繼續調用刪除方法
- 接下來就去調用addDeleteMappedStatement進行具體操作
總結
以上是生活随笔為你收集整理的MP 启动注入 SQL 原理分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CentOS 7 安装版本管理 GitL
- 下一篇: Excel 数据导入到Access数据库