淺談Mybatis Plus的BaseMapper的方法是如何注入的
Mybatis Plus的BaseMapper的方法
我們在用的時(shí)候經(jīng)常就是生產(chǎn)自定義的Mapper繼承自BaseMapper,然后我們就可以使用了,但是有沒想過BaseMapper里的方法是怎么被注入到mybatis里的,也沒看到什么xml啊,今天我們就來看看是怎么回事。

Mybatis Plus的初始化方法
MybatisPlusAutoConfiguration中的SqlSessionFactory
在創(chuàng)建的時(shí)候會(huì)創(chuàng)建MybatisSqlSessionFactoryBean,然后設(shè)置MybatisConfiguration作為配置類。

MybatisConfiguration是繼承自Configuration的:

自定義了一個(gè)MybatisMapperRegistry注冊器,后面會(huì)用到。

BaseMapper方法的注入的過程
MybatisSqlSessionFactoryBean的初始化后方法afterPropertiesSet調(diào)用buildSqlSessionFactory創(chuàng)建SqlSessionFactory:

其實(shí)就會(huì)去解析自定義的mapper的xml文件:


其中有個(gè)addMapper的方法,是前面MybatisConfiguration調(diào)用的。

會(huì)解析出對應(yīng)的類型,然后內(nèi)部調(diào)用MybatisMapperRegistry的方法:

內(nèi)部最后是MybatisMapperAnnotationBuilder去解析的:

里面會(huì)進(jìn)行基本的SQL方法注入:


完成每個(gè)方法的注入:

注入的實(shí)現(xiàn):

其實(shí)每一個(gè)AbstractMethod的子類都會(huì)實(shí)現(xiàn)自己的injectMappedStatement:


最后會(huì)去枚舉類SqlMethod中獲取對應(yīng)的枚舉,里面就是類似定義在xml中的信息,最后轉(zhuǎn)換為sqlSource再進(jìn)行封裝:

SqlMethod 枚舉值:
public enum SqlMethod {
/**
* 插入
*/
INSERT_ONE("insert", "插入一條數(shù)據(jù)(選擇字段插入)", "<script>\nINSERT INTO %s %s VALUES %s\n</script>"),
UPSERT_ONE("upsert", "Phoenix插入一條數(shù)據(jù)(選擇字段插入)", "<script>\nUPSERT INTO %s %s VALUES %s\n</script>"),
/**
* 刪除
*/
DELETE_BY_ID("deleteById", "根據(jù)ID 刪除一條數(shù)據(jù)", "<script>\nDELETE FROM %s WHERE %s=#{%s}\n</script>"),
DELETE_BY_MAP("deleteByMap", "根據(jù)columnMap 條件刪除記錄", "<script>\nDELETE FROM %s %s\n</script>"),
DELETE("delete", "根據(jù) entity 條件刪除記錄", "<script>\nDELETE FROM %s %s %s\n</script>"),
DELETE_BATCH_BY_IDS("deleteBatchIds", "根據(jù)ID集合,批量刪除數(shù)據(jù)", "<script>\nDELETE FROM %s WHERE %s IN (%s)\n</script>"),
/**
* 邏輯刪除
*/
LOGIC_DELETE_BY_ID("deleteById", "根據(jù)ID 邏輯刪除一條數(shù)據(jù)", "<script>\nUPDATE %s %s WHERE %s=#{%s} %s\n</script>"),
LOGIC_DELETE_BY_MAP("deleteByMap", "根據(jù)columnMap 條件邏輯刪除記錄", "<script>\nUPDATE %s %s %s\n</script>"),
LOGIC_DELETE("delete", "根據(jù) entity 條件邏輯刪除記錄", "<script>\nUPDATE %s %s %s %s\n</script>"),
LOGIC_DELETE_BATCH_BY_IDS("deleteBatchIds", "根據(jù)ID集合,批量邏輯刪除數(shù)據(jù)", "<script>\nUPDATE %s %s WHERE %s IN (%s) %s\n</script>"),
/**
* 修改
*/
UPDATE_BY_ID("updateById", "根據(jù)ID 選擇修改數(shù)據(jù)", "<script>\nUPDATE %s %s WHERE %s=#{%s} %s\n</script>"),
UPDATE("update", "根據(jù) whereEntity 條件,更新記錄", "<script>\nUPDATE %s %s %s %s\n</script>"),
/**
* 邏輯刪除 -> 修改
*/
LOGIC_UPDATE_BY_ID("updateById", "根據(jù)ID 修改數(shù)據(jù)", "<script>\nUPDATE %s %s WHERE %s=#{%s} %s\n</script>"),
/**
* 查詢
*/
SELECT_BY_ID("selectById", "根據(jù)ID 查詢一條數(shù)據(jù)", "SELECT %s FROM %s WHERE %s=#{%s} %s"),
SELECT_BY_MAP("selectByMap", "根據(jù)columnMap 查詢一條數(shù)據(jù)", "<script>SELECT %s FROM %s %s\n</script>"),
SELECT_BATCH_BY_IDS("selectBatchIds", "根據(jù)ID集合,批量查詢數(shù)據(jù)", "<script>SELECT %s FROM %s WHERE %s IN (%s) %s</script>"),
SELECT_ONE("selectOne", "查詢滿足條件一條數(shù)據(jù)", "<script>%s SELECT %s FROM %s %s %s\n</script>"),
SELECT_COUNT("selectCount", "查詢滿足條件總記錄數(shù)", "<script>%s SELECT COUNT(%s) FROM %s %s %s\n</script>"),
SELECT_LIST("selectList", "查詢滿足條件所有數(shù)據(jù)", "<script>%s SELECT %s FROM %s %s %s\n</script>"),
SELECT_PAGE("selectPage", "查詢滿足條件所有數(shù)據(jù)(并翻頁)", "<script>%s SELECT %s FROM %s %s %s\n</script>"),
SELECT_MAPS("selectMaps", "查詢滿足條件所有數(shù)據(jù)", "<script>%s SELECT %s FROM %s %s %s\n</script>"),
SELECT_MAPS_PAGE("selectMapsPage", "查詢滿足條件所有數(shù)據(jù)(并翻頁)", "<script>\n %s SELECT %s FROM %s %s %s\n</script>"),
SELECT_OBJS("selectObjs", "查詢滿足條件所有數(shù)據(jù)", "<script>%s SELECT %s FROM %s %s %s\n</script>");
private final String method;
private final String desc;
private final String sql;
SqlMethod(String method, String desc, String sql) {
this.method = method;
this.desc = desc;
this.sql = sql;
}
public String getMethod() {
return method;
}
public String getDesc() {
return desc;
}
public String getSql() {
return sql;
}
}
最終還是調(diào)用了MapperBuilderAssistant的addMappedStatement進(jìn)行注冊:

總結(jié)
- 初始化注入自定義的MybatisConfiguration和MybatisMapperRegistry。
- 解析Mapper類,獲取方法對應(yīng)的AbstractMethod。
- 調(diào)用各自的實(shí)現(xiàn)進(jìn)行去SqlMethod獲取對應(yīng)的枚舉,獲取到信息后進(jìn)行注冊。
其實(shí)就相當(dāng)于代碼里面定義了原本需要再xx.xml定義的數(shù)據(jù),直接在代碼中獲取注入常用的CRUD操作即可。
到此這篇關(guān)于淺談Mybatis Plus的BaseMapper的方法是如何注入的的文章就介紹到這了,更多相關(guān)Mybatis Plus BaseMapper注入內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis-Plus接口BaseMapper與Services使用詳解
- MybatisPlus?BaseMapper?實(shí)現(xiàn)對數(shù)據(jù)庫增刪改查源碼
- Mapper層繼承BaseMapper<T>需要引入的pom依賴方式
- mybatis抽取基類BaseMapper增刪改查的實(shí)現(xiàn)
- mybatis-plus中BaseMapper入門使用
- MybatisPlus BaseMapper 中的方法全部 Invalid bound statement (not found Error處理)
- Mybatis-Plus BaseMapper的用法詳解
- BaseMapper接口的使用方法
相關(guān)文章
Spring Cloud體系實(shí)現(xiàn)標(biāo)簽路由的方法示例
這篇文章主要介紹了Spring Cloud體系實(shí)現(xiàn)標(biāo)簽路由的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05
用html css javascript打造自己的RIA圖文教程
用html&css&javascript打造自己的RIA之一,包括了配置等2009-07-07
Maven遠(yuǎn)程倉庫地址修改實(shí)現(xiàn)解析
這篇文章主要介紹了Maven遠(yuǎn)程倉庫地址修改實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
Windows同時(shí)安裝兩個(gè)版本JDK并實(shí)現(xiàn)動(dòng)態(tài)切換JAVA8或JAVA11的方法
這篇文章主要給大家介紹了關(guān)于Windows同時(shí)安裝兩個(gè)版本JDK并實(shí)現(xiàn)動(dòng)態(tài)切換JAVA8或JAVA11的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-11-11
SpringBoot中properties,yml,yaml的區(qū)別及使用說明
這篇文章主要介紹了SpringBoot中properties,yml,yaml的區(qū)別及使用說明,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
分析Java中ArrayList與LinkedList列表結(jié)構(gòu)的源碼
這篇文章主要介紹了Java中ArrayList與LinkedList列表結(jié)構(gòu)的源碼,文章最后對LinkedList和ArrayList以及Vector的特性有一個(gè)對比總結(jié),需要的朋友可以參考下2016-05-05
Java中static與instance的區(qū)別及作用詳解
這篇文章主要為大家介紹了Java中static與instance的區(qū)別及作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Java用 Rhino/Nashorn 代替第三方 JSON 轉(zhuǎn)換庫
本篇文章主要介紹了Java用 Rhino/Nashorn 代替第三方 JSON 轉(zhuǎn)換庫,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05

