在springBoot中使用Mapper类问题
文章目录背景xml文件跟mapper分开方式一application.properties主程序类Mapper方式二注意点xml文件跟mapper在同一个目录下application.properties在mapper包下主程序类感想背景版本如下:springboot=1.5.9jdk=1.8maven=3.5在springBoot中使用mapper类,因为有其xml文件的存在,所以其xml文件的
文章目录
背景
版本如下:
springboot=1.5.9
jdk=1.8
maven=3.5
xml文件跟mapper分开
方式一
当xml文件跟mapper文件分开的时候,也就是将xml文件放在springBoot下的src/main/resources文件下,如下所示:
application.properties
当分开的时候,我们需要在application.properties主配置文件中配置如下:
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=com.drillsb.demo.pojo
mybatis.mapper-locations
这个是xml文件的路径
第二个:
mybatis.type-aliases-package
这个是项目所在的pojo的路径
主程序类
为了让mybatis扫描到我们的包,还需要在主程序中声明Mapper包的扫描,如下:
Mapper
照理来说,按照Mybatis的配置,使用xml文件配置Mapper类的话,不需要在Mapper类中添加注解的,当我们在Service类中直接调用就是了,因为配置文件指明了;但是这样是不行的!
当我们在Service中调用的时候,还是会报无法注入,如下展示:
在PermissionMapper类中:
之后在Service类中使用Autowired注入,如下:
注意了:
这样虽然报错,但是项目运行没有一点影响!
这样虽然报错,但是项目运行没有一点影响!
这样虽然报错,但是项目运行没有一点影响!
如图运行成功:
也就是说是无伤大雅的,也符合前面说的;
但是要想消除这个idea的报错也可以滴;无法注入,是说没有这样的Bean存在,那么我们就添加一个注解,注入Bean嘛,所以在Mapper包下的所有mapper接口添加一个
@Repository注解
或者是
@Component注解
其效果是一样的,都是告知spring管理这个类为Bean;但是个人还是习惯使用@Repository注解,毕竟这个是spring专门用于标注Dao类的;
这样就不会有报错了,如下:
方式二
在方式一中,我们需要在主程序类中告诉Mybatis扫描mapper包;添加@MapperScan注解
如下:
我们也可以在每一个mapper接口中添加@Mapper注解,这样就不需要在主程序类中添加扫描了;如下:
当然方式二,较为麻烦,还是喜欢方式一。。。。
注意点
在上面的两种方式中,有一个绕不开的点,就是在resources目录下创建的目录的时候,跟在java目录下创建目录是不一样的;
在java文件中我们创建的目录可以使用
.
这样表示子级目录,但是在resources文件下创建使用.
idea创建的时候就会误认为是一个名字,如下这样创建:
在盘符系统中,是这样的:
点开之后就只是一个文件,如下:
实际上我们需要使用的是子级目录形式,也就是在application.properties中写的:
mybatis.mapper-locations=classpath:mapper/*.xml
是一个目录路径;
所以,在resources目录下创建文件,需要以/创建,如下这样的形式:
当我们创建之后,会发现,是跟用.创建出来的一模一样的名字,如下:
但是,这两者是不一样的!!!
但是,这两者是不一样的!!!
但是,这两者是不一样的!!!
这个锅就是idea来背!!!!!当我们打开其目录结构,就可以发现,如下:
惊喜加以外。。。。。。。
点开之后如下:
唉,就这个问题,困扰了我很久很久!!!
但是idea本身也可查看其到底是否是一个目录,如下:
这样就可以显示是否是一个目录结构了,如下:
大大感谢下面博文,鞠躬!!!!
参考的博文:
【Spring Boot】1.解决IDEA中springboot整合mybatis中出现的Invalid bound statement(not found)的问题
springboot整合mybatis中*Mapper无法注入或注入失败的问题
Spring 与 Mybatis 中的 @Repository 与 @Mapper
解决IDEA中 Invalid bound statement (not found):的问题
xml文件跟mapper在同一个目录下
这个就不分方式一跟方式二了;因为只是注解所处方式以及数量不同;
这个也是idea的坑。。。。。。
application.properties
在application.properties文件中,如下:
mybatis.mapper-locations=classpath:com.drillsb.demo.mapper/*.xml
mybatis.type-aliases-package=com.drillsb.demo.pojo
在mapper包下
将原来在resources的mapper目录下的xml文件全部剪切到mapper包下,如下:
主程序类
主程序类还是指明了Mybatis扫描的包,如下:
然后运行主程序类,再访问,如下:
报错:无法使用在mapper包下xml文件中指明的语句;
注意了
xml文件是没有问题的,其它的也没有问题的;因为按照前面分开mapper类和xml文件,运行及其功能都是没有问题的!!!
并且在Ecplise中运行,按照上面的方式去配置,运行也没问题。。。。
但是在idea中就是不行。。。。。。。
百度了好大一会儿,才解决;
在idea中,默认情况下是不会去编译src/main/java下的xml文件的!!!
在idea中,默认情况下是不会去编译src/main/java下的xml文件的!!!
在idea中,默认情况下是不会去编译src/main/java下的xml文件的!!!
所以需要我们自己配置src/main/java也可以编译资源文件,在pom.xml文件中,如下:
<!-- 资源路径-->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
注意这个资源是配置到build标签下的
然后当我们再运行的时候,就成功了~~~~
如下:
并且在编译文件中也有,如下:
参考博文:
Mybatis在IDEA中找不到mapper映射文件
感想
一篇写下来花了好几个小时,当然收获也不浅!总算是解决了;码字不易,如果有帮助的话,帅哥美女们点个赞好嘛!!!
更多推荐
所有评论(0)