解决 org.apache.ibatis.exceptions.PersistenceException
哇,今天整合ssm时, 我被一向自信的mybatis秀了, 之所以这么说, 我最近的两个项目都没有在这里翻车, 今天的我疯了, 好在老司机就是老司机 重新挂挡,稳稳上路…
上面是我遇到的问题, 本来我解决之后, 就继续整合, 想想还是贡献下我的思路, 以后说不定还会遇到:
最详细的解决方案,没有之一!!!
-
1.先看你的mapper
接口的全类名
和映射的xml文件的namespace
是否相同 -
2.观察你的xxx
接口的方法名
是否和xml文件的id值
是否相同 -
3.实体类的
属性名
和 resultMap的property属性值
是否相同,或者缺少, 表的字段和column属性值
是否相同 -
4.接口的方法顺序和xml文件的所有id顺序是否一致
-
5.如果有级联 association 或者 collection 还要特别注意
select属性值
是:目标xml的namespace + id值 (我就是这个问题) -
6.新增映射文件xml 时,一定及时查看配置文件是否对应添加上
以上俗称黄金六则
,祝各位修仙之路顺利, 老衲即将飞升…
(不用怀疑没有听过, 对 ,是我编的,啊哈哈哈哈哈…)
注: 如果你看到这还没有解决,可能还有两个原因:
- 你瞎了
- 如果还有别的原因,你可以了来捶我了 (吃瓜…)
思路分析
为了避免被锤, 我还是在掏点东西出来, 不至于被锤的太惨
不知道各位有没有注意到我开头的截图里的箭头
那就是排错法宝:
一般报错,我们只需看首的第一句和尾部的最后一句, 以我上面的截图为例,你可以大致定位到时某个xml文件,甚至有时候直接定位到哪一个sql语句上 ,然后将上面的黄金6则 依次对比, 99%都能解决 (避免被锤, 嘿嘿,极强大的求生欲)