解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题

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

需要检查的步骤:

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

2.注意mapper.xml文件中的namespace是否正确指向到Mapper.java类的位置 【<mapper namespace="com.swapping.springcloud.ms.integral.mapper.IntegralMapper">】

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

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

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

6.注意在配置文件properties中指明mapper.xml文件所在的位置

#mybatis
mybatis.mapper-locations=classpath:mapper/*.xml
#mybatis指定entity位置
mybatis.type-aliases-package=com.swapping.springcloud.ms.integral.domain

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

解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题

然后我自己报出这个错,找了一下午,各种对名字,百度的方法都不管用,最终发现了问题所在原因是----- resources 底下xml和mapper接口的路径不同,这里我创建的包名是com.bwai.mapper,它在这里不是一级一级的创建文件夹而是创建了一个com.bwai.mapper名字的一个包,所以需要com/bwai/mapper 这样创建

解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题

上一篇:解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题


下一篇:SpringCloud-Stream实战入门(二,缓存架构技术