异常信息如下:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.example.demo.mapper.UserMapper.insertOne
at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235)
at org.apache.ibatis.binding.MapperMethod.<init>(MapperMethod.java:53)
at org.apache.ibatis.binding.MapperProxy.lambda$cachedInvoker$0(MapperProxy.java:108)
at java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660)
at org.apache.ibatis.util.MapUtil.computeIfAbsent(MapUtil.java:35)
at org.apache.ibatis.binding.MapperProxy.cachedInvoker(MapperProxy.java:95)
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:86)
at com.sun.proxy.$Proxy72.insertOne(Unknown Source)
at com.example.demo.DemoApplicationTests.contextLoads(DemoApplicationTests.java:28)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
。。。。。。
就是一个很常见的BindingException,就是xml文件和mapper接口没有进行绑定,出现这种情况原因很多,之前也踩过坑。但是这次找了半天没找到,最后发现是resoures下的包路径写得有问题。
配置文件如下:
mybatis.mapper-locations=classpath:com/example/demo/mapper/*.xml
mybatis.configuration.map-underscore-to-camel-case=true
表明我要扫描这个路径下的xml文件,但是我创建的时候直接这样创建目录:
这样实际创建的是一个单级目录,只是目录名叫com.example.demo.mapper
,而我的配置文件的期望是com/example/demo/mapper
这样的多级目录,导致路径不匹配,所以无法找到xml文件与mapper接口进行绑定。如果期望创建多级目录,应该创建com
目录,然后在com
目录下右键,创建子目录example
,如此直至创建mapper
目录。
二者创建的效果对比:
因为这种小问题浪费半天时间,属实不应该,希望能帮兄弟们闭坑。