淺談Springboot下引入mybatis遇到的坑點(diǎn)
配置完成后,訪問數(shù)據(jù)庫(kù)遇到的問題
首先出現(xiàn)這個(gè)問題,肯定是xml文件與mapper接口沒有匹配上,甚至是xml文件根本沒有被掃描到。
于是會(huì)從配置上進(jìn)行檢查:1、 xml中的namespace命名是否與mapper接口路徑一致,需保證一致。
2、 application.properties或者application.yml文件中配置mybatis的屬性對(duì)否,如下:
第一行 typeAliasesPackage是實(shí)體類的包路徑;
第二行mapperLocations:是Mapper的xml文件存放的位置,當(dāng)xml文件跟對(duì)應(yīng)的Mapper接口處于同一位置的時(shí)候可以不用指定
該屬性的值。
3、 啟動(dòng)類上加注解,如下:
推薦用這種方式掃描Mapper接口,另一種方式是在每一個(gè)mapper接口類上加注解
注意,上述兩種方式,必須有一種實(shí)現(xiàn),不然無(wú)法啟動(dòng)項(xiàng)目,會(huì)報(bào)mapper接口未注入,如下:
綜上,只要上面幾種情況都配置正確,一般就可以正常啟動(dòng),并訪問數(shù)據(jù)庫(kù)。
二、 springBoot + MybatisPluspom中需要修改包
我用同樣的原理,準(zhǔn)備在springBoot中引入mybatisPlus,但是配置都檢查了,依舊報(bào)類似的錯(cuò)誤:
1、 首先由于mybatis通過mapper接口來(lái)invoke具體的方法實(shí)現(xiàn),其查詢的key是接口包名加方法名,如果找不到該key,就會(huì)報(bào)錯(cuò),具體代碼如下:
只有在configuration中找到了匹配的key,才會(huì)返回key對(duì)應(yīng)的MappedStatement; 同樣調(diào)用selectById,可看到一下結(jié)果,能夠找到。很明顯而由于上面的selectById1方法是自定義實(shí)現(xiàn)的,其xml未被掃描到,還是配置的問題。
然后,再看源碼,為何configuration中找不到自定義的mapper方法,配置哪里有問題:
MybatisPlusAutoConfiguration是在啟動(dòng)時(shí),自動(dòng)會(huì)讀取配置信息的,可以看到其中MybatisPlusProperties類型定義了前綴mybatis-plus,即只有前綴為mybatis-plus的配置信息才會(huì)被加載,而再看配置文件,如下,恍然大悟,mybatis的配置前綴寫錯(cuò)了,修改成mybatis-plus,成功了?。?!
后來(lái)發(fā)現(xiàn),原來(lái)這跟開頭pom文件中導(dǎo)入的包版本有關(guān)系,
總結(jié)如下:若使用的是mybatis,則要導(dǎo)入的包是下面這個(gè),并且配置文件中mybatis的配置前綴是“mybatis”。
而若使用的是mybatis-plus,則需要導(dǎo)入的包是下圖,并且配置中mybatis的配置前綴是“mybatis-plus”。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. IDEA EasyCode 一鍵幫你生成所需代碼2. IntelliJ IDEA設(shè)置條件斷點(diǎn)的方法步驟3. Java構(gòu)建JDBC應(yīng)用程序的實(shí)例操作4. Spring應(yīng)用拋出NoUniqueBeanDefinitionException異常的解決方案5. ThinkPHP5 通過ajax插入圖片并實(shí)時(shí)顯示(完整代碼)6. javascript設(shè)計(jì)模式 ? 建造者模式原理與應(yīng)用實(shí)例分析7. 一篇文章帶你了解JavaScript-對(duì)象8. Python使用oslo.vmware管理ESXI虛擬機(jī)的示例參考9. Express 框架中使用 EJS 模板引擎并結(jié)合 silly-datetime 庫(kù)進(jìn)行日期格式化的實(shí)現(xiàn)方法10. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟
