在用Spring Boot项目中整合MyBatis时,mapper接口上用的注解是以前学spring时用的@Repository注解(由于整合了Mybatis,所以@Repository基本不用了)产生了错误。
在此总结一下@Repository 与 @Mapper的区别
1、@Repository(不常用,略讲)
@Repository 是 Spring 中的注解,用于声明一个 Bean。@Repository不可以单独使用。Spring中在mapper接口上写一个@Repository注解,只是为了标识,要想真正是这个接口被扫描,必须使用@MapperScannerConfigurer
加上@MapperScannerConfigurer注解后会扫描mapper包下所有的接口,然后自动创建各自的动态代理类。
具体与Spring集成可分三个步骤:
- 把Java类对应的Mapper接口类放入Spring中的IOC容器,交给IOC统一管理。
- 把Java类对应的XML命名空间添加到Mybatis中的Configuration类中的mapperRegistry(用于管理Mybatis的Mapper)
- 使用Spring中的IOC容器拓展FactoryBean获取到Mapper的实例。(第一步纳入Spring只是接口)
2、@Mapper
@Mapper是MyBatis自带的注解。在Spring程序中,MyBatis需要找到对应的mapper,在编译时生成动态代理类,与数据库进行交互,这时需要用到@Mapper注解
但是有时候当我们有很多mapper接口时,就需要写很多@Mappe注解,这样很麻烦,有一种简便的配置化方法便是在启动类上使用@MapperScan注解。
还有一个@MapperScans注解(几乎不用),这个注解可以扫描多个包下的接口。
这样可以自动扫描包路径下所有的mapper接口,从而不用再在接口上添加任何注解。
3、区别
相同点
@Mapper和@Repository都是作用在Dao层接口,使得其生成代理对象Bean,交给Spring 的IOC容器管理,对于MyBatis来说,都可以不用写mapper.xml文件
不同点
- @Mapper不需要配置扫描地址,可以单独使用,如果有多个mapper文件的话,可以在项目启动类中加入@MapperScan(“mapper文件所在包”)
- @Repository不可以单独使用,否则会报错误,要想用,必须配置扫描地址(@MapperScannerConfigurer)