解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题,需要检查的步骤&#x


org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题,即在mybatis中dao接口与mapper配置文件在做映射绑定的时候出现问题,简单说,就是接口与xml要么是找不到,要么是找到了却匹配不到。

需要检查的步骤:

1.是否mapper.java文件上使用了注解@Mapper  或者 在启动类上扫描了Mapper类 @MapperScan("com.heima.model.mappers")   【注意扫描的包名是否正确】

2.注意mapper.xml文件中的namespace是否正确指向到Mapper.java类的位置 【<mapper namespace="com.heima.model.mappers.app.ApUserArticleListMapper">】

3.注意被调用的方法名在mapper.java中和mapper.xml中的id保持一致性

4.注意mapper.xml方法的parameterType尽量指定全路径的domain

5.注意Mapper.java在被调用的地方需要注入@Autowired

6.最终,一定一定要注意你建立的mapper.xml是xml文件,因为你创建的file在idea上默认会被识别为xml文件的图标,即使你没有指明后缀!!!

参照下图检查

1.检查java配置文件类上是否使用了注解@Mapper  或者在启动类上扫描了Mapper类,注意扫描的包名是否正确 

2.注意mapper.xml文件中的namespace是否正确指向到Mapper.java类的位置

3.注意被调用的方法名在mapper.java中和mapper.xml中的id保持一致性

 

4.注意mapper.xml方法的parameterType尽量指定全路径的domain

5.注意Mapper.java在被调用的地方需要注入@Autowired

6.最终,一定一定要注意你建立的mapper.xml是xml文件,因为你创建的file在idea上默认会被识别为xml文件的图标,即使你没有指明后缀!!!

然后我自己报出这个错,找了一下午,各种对名字,百度的方法都不管用,最终发现了问题所在原因是-----> resources 底下xml和mapper接口的路径不同,

这里我创建的包名是cmappers.app,它在这里不是一级一级的创建文件夹而是创建了一个mappers.app名字的一个包 ,

所以需要cmappers/app 这样创建

相关内容