Mybatis 中Mapper使用package方式配置報錯的解決方案
Mybatis 中Mapper使用package方式配置報錯
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
UserDaoTest中調(diào)用了UserDao的insert方法。
1.項目結(jié)構(gòu)如下package com.mybatis.dao; import org.apache.ibatis.annotations.Mapper;import org.apache.ibatis.annotations.Param; import java.util.List;import com.mybatis.pojo.User; @Mapperpublic interface UserDao { void insert( User user); int insertSelective(@Param('user') User user); int insertList(@Param('users') List<User> users); int update(@Param('user') User user); User findbyId(@Param('id')Integer id); }3.UserDao.xml
已經(jīng)按照正常的package的配置方式,將接口與xml文件放在同一個目錄下,其他配置也沒問題,就是報找不到UserDao中的方法。
結(jié)果去target中看了一眼發(fā)現(xiàn),xml文件沒加載。。。。。
解決方案原來是IDEA maven項目默認(rèn)不會把src下除java文件外的文件打包到classes文件夾下,需要在maven中增加配置如下
<build><resources> <resource><directory>src/main/java</directory><includes> <include>**/*.xml</include></includes><!--默認(rèn)是true--><!--<filtering>true</filtering>--> </resource></resources> </build>
這樣xml文件就可以加載了,動態(tài)代理為UserDao接口生成實現(xiàn)類,而實現(xiàn)類的具體實現(xiàn)細節(jié)就是在xml中,通過package掃描的方式找到xml,就可以正確的生成UserDao的代理類了。
而xml無法加載,就會造成動態(tài)代理生成的代理類是無效的(這個代理類對象是可以生成的),當(dāng)調(diào)用方法就會出現(xiàn)開頭的錯誤。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. mysql like語句問題2. Mysql入門系列:MYSQL創(chuàng)建、刪除和選擇數(shù)據(jù)庫3. 用SQL Server為Web瀏覽器提供圖像(三)(轉(zhuǎn))4. MySQL中InnoDB和MyISAM類型的差別5. 解決mybatis一對多關(guān)聯(lián)查詢多條數(shù)據(jù)只顯示一條的問題6. Windows下在DOS用mysql命令行導(dǎo)入.sql文件7. 恢復(fù)誤刪數(shù)據(jù)(SQL Server 2000)--Log Explorer8. MYSQL技巧:為現(xiàn)有字段添加自增屬性9. Mysql入門系列:MYSQL服務(wù)器內(nèi)部安全性-安全數(shù)據(jù)目錄訪問10. SQLite3的綁定函數(shù)族使用與其注意事項詳解
