淺談Mybatis Plus的BaseMapper的方法是如何注入的
Mybatis Plus的BaseMapper的方法
我們?cè)谟玫臅r(shí)候經(jīng)常就是生產(chǎn)自定義的Mapper繼承自BaseMapper,然后我們就可以使用了,但是有沒(méi)想過(guò)BaseMapper里的方法是怎么被注入到mybatis里的,也沒(méi)看到什么xml啊,今天我們就來(lái)看看是怎么回事。
Mybatis Plus的初始化方法
MybatisPlusAutoConfiguration中的SqlSessionFactory
在創(chuàng)建的時(shí)候會(huì)創(chuàng)建MybatisSqlSessionFactoryBean,然后設(shè)置MybatisConfiguration作為配置類。
MybatisConfiguration是繼承自Configuration的:
自定義了一個(gè)MybatisMapperRegistry注冊(cè)器,后面會(huì)用到。
BaseMapper方法的注入的過(guò)程
MybatisSqlSessionFactoryBean的初始化后方法afterPropertiesSet調(diào)用buildSqlSessionFactory創(chuàng)建SqlSessionFactory:
其實(shí)就會(huì)去解析自定義的mapper的xml文件:
其中有個(gè)addMapper的方法,是前面MybatisConfiguration調(diào)用的。
會(huì)解析出對(duì)應(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中獲取對(duì)應(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ù)(并翻頁(yè))", "<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ù)(并翻頁(yè))", "<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)行注冊(cè):
總結(jié)
- 初始化注入自定義的MybatisConfiguration和MybatisMapperRegistry。
- 解析Mapper類,獲取方法對(duì)應(yīng)的AbstractMethod。
- 調(diào)用各自的實(shí)現(xiàn)進(jìn)行去SqlMethod獲取對(duì)應(yīng)的枚舉,獲取到信息后進(jìn)行注冊(cè)。
其實(shí)就相當(dāng)于代碼里面定義了原本需要再xx.xml定義的數(shù)據(jù),直接在代碼中獲取注入常用的CRUD操作即可。
到此這篇關(guān)于淺談Mybatis Plus的BaseMapper的方法是如何注入的的文章就介紹到這了,更多相關(guān)Mybatis Plus BaseMapper注入內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis-Plus接口BaseMapper與Services使用詳解
- MybatisPlus?BaseMapper?實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)增刪改查源碼
- 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)文章
在Mybatis中association標(biāo)簽多層嵌套的問(wèn)題
這篇文章主要介紹了在Mybatis中association標(biāo)簽多層嵌套的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java如何讀取某個(gè)文件夾中的全部文件(包括子文件夾)
這篇文章主要介紹了java如何讀取某個(gè)文件夾中的全部文件(包括子文件夾),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Filter、Servlet、Listener的學(xué)習(xí)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Filter、Servlet、Listener的學(xué)習(xí)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07Mybatis中<if>和<choose>的區(qū)別及“=”判斷方式
這篇文章主要介紹了Mybatis中<if>和<choose>的區(qū)別及“=”判斷方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06java中使用session監(jiān)聽(tīng)實(shí)現(xiàn)同帳號(hào)登錄限制、登錄人數(shù)限制
本文主要介紹了java中使用session監(jiān)聽(tīng)實(shí)現(xiàn)同帳號(hào)登錄限制、登錄人數(shù)限制,通過(guò)session來(lái)監(jiān)聽(tīng)在線人數(shù)和登陸限制,有需要的童鞋可以了解一下。2016-10-10SpringBoot + minio實(shí)現(xiàn)分片上傳、秒傳、續(xù)傳功能
MinIO是一個(gè)基于Go實(shí)現(xiàn)的高性能、兼容S3協(xié)議的對(duì)象存儲(chǔ),使用MinIO構(gòu)建用于機(jī)器學(xué)習(xí),分析和應(yīng)用程序數(shù)據(jù)工作負(fù)載的高性能基礎(chǔ)架構(gòu),這篇文章主要介紹了SpringBoot + minio實(shí)現(xiàn)分片上傳、秒傳、續(xù)傳,需要的朋友可以參考下2023-06-06ArrayList與linkedList的用法區(qū)別及擴(kuò)容方式
這篇文章主要介紹了ArrayList與linkedList的用法區(qū)別及擴(kuò)容方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03SpringBoot開發(fā)技巧啟動(dòng)時(shí)配置校驗(yàn)實(shí)現(xiàn)示例
這篇文章主要為大家介紹了SpringBoot開發(fā)在啟動(dòng)時(shí)自動(dòng)配置校驗(yàn)的實(shí)現(xiàn)示例及原理解析,有需要的朋友可以借鑒參考下希望能夠有所幫助2021-10-10