Spring Boot MyBatis注解:@MapperScan和@Mapper

目录

最近参与公司的新项目架构搭建,在使用 mybatis 的注解时,和同时有了不同意见,同事认为使用 @Mapper 注解简单明了,而我建议使用 @MapperScan,直接将 mapper 所在的目录扫描进去就行,而且 @Mapper 需要在每一个 mapper 上都添加,繁琐。同事又说 -- 我们可以用逆向工程自动生产 entity,mapper,service 时,将注解加上,很方便的,于是各执一词。

下面是我整理的这两种方法的比较:

  使用 @Mapper 注解

  为了让 DemoMapper 能够让别的类进行引用,我们可以在 DemMapper 类上添加 @Mapper 注解:

@Mapper 
public interface DemoMapper { 
@Insert("insert into Demo(name) values(#{name})") @Options(keyProperty="id",keyColumn="id",useGeneratedKeys=true) 
public void save(Demo demo); } 

 

  直接在 Mapper 类上面添加注解 @Mapper,但是这种方式要求每一个 mapper 类都需要添加此注解,麻烦。

  使用 @MapperScan 注解

  通过使用 @MapperScan 可以指定要扫描的 Mapper 类的包的路径,比如:

@SpringBootApplication 
@MapperScan("com.kfit.*.mapper") 
public class App { 
  public static void main(String[] args) {
    SpringApplication.run(App.class, args);
  }
}

  或者:

@SpringBootApplication 
@MapperScan("com.kfit.mapper") 
public class App { 
    public static void main(String[] args) { 
        SpringApplication.run(App.class, args);} 
} 

  可以根据包的结构指定不同的表达式。

  使用 @MapperScan 注解多个包

  可以使用如下的方式指定多个包: 

@SpringBootApplication @MapperScan({"com.kfit.demo","com.kfit.user"}) 
public class App {
    public static void main(String[] args) { 
        SpringApplication.run(App.class, args);} 
}     

  如果 mapper 类没有在 Spring Boot 主程序可以扫描的包或者子包下面,可以使用如下方式进行配置:  

@SpringBootApplication @MapperScan({"com.kfit.*.mapper","org.kfit.*.mapper"}) 
public class App { 
    public static void main(String[] args) { 
        SpringApplication.run(App.class, args);} 
}    

 

作者:JackpotHan
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。