记一次使用mybatis,Mapper接口和mapper.xml文件无法绑定的问题

异常信息如下:

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文件,但是我创建的时候直接这样创建目录:
记一次使用mybatis,Mapper接口和mapper.xml文件无法绑定的问题_第1张图片
这样实际创建的是一个单级目录,只是目录名叫com.example.demo.mapper,而我的配置文件的期望是com/example/demo/mapper这样的多级目录,导致路径不匹配,所以无法找到xml文件与mapper接口进行绑定。如果期望创建多级目录,应该创建com目录,然后在com目录下右键,创建子目录example,如此直至创建mapper目录。

二者创建的效果对比:
记一次使用mybatis,Mapper接口和mapper.xml文件无法绑定的问题_第2张图片
因为这种小问题浪费半天时间,属实不应该,希望能帮兄弟们闭坑。

你可能感兴趣的:(bug记录,mybatis,xml,java)