原本准备研究下mybatis源码执行流程的,就随意搭建了个项目,全部配置以下:java
一切看似都是那么的正常,然而执行的时候:Exception in thread "main" org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.nijunyang.mybatis.mapper.UserMapper.insertUserapache
1.发现org.apache.ibatis.session.Configuration#mappedStatements始终是空的,等于说mapper文件的类容根本没有被加载解析session
2.org.apache.ibatis.builder.annotation.MapperAnnotationBuilder#loadXmlResource加载xml根本没有加载到mybatis
3.文件路径看似都是对的,可是却加载不到文件流org.apache.ibatis.io.Resources#getResourceAsStream(java.lang.ClassLoader, java.lang.String)app
各类找问题,觉得是名字不对等等,从新写各项配置,结果仍是不行。最后恍然大悟,这配置文件是用classloader加载的,遂检查jar包(class目录)发现mapper.xml文件根本没有编译进去,再看pom文件,资源文件的打包配置空空如也。ui
因此看似正常的xml文件路径,实则并不正常,由于在jar/class里面并无将配置文件打进去spa
所以在源文件包里面写配置,pom文件必定要注意加上打包资源的配置3d
所以在源文件包里面写配置,pom文件必定要注意加上打包资源的配置xml
所以在源文件包里面写配置,pom文件必定要注意加上打包资源的配置
blog
默认的编译只会将java源文件编译出来的class文件打包走,而不会打包其余文件,撸上<resources>节点万事大吉