springboot整合mybatisplus中@Mapper与@MapperScan的使用

x33g5p2x  于2021-12-03 转载在 Spring  
字(1.5k)|赞(0)|评价(0)|浏览(462)

一、@Mapper与@MapperScan不可同时使用

二、@Mapper用于注解单个mapper接口

三、@Mapper Scan用于批量注解Mapper接口

四、@Mapper不起作用时,因为缺少下图中的依赖包

以上为自己整合框架中遇到的问题与解决方案,如果以上解决方案不能解决您的问题,可以与我联系讨论

如果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);  
    }  
}

使用

(1)方式一:使用@Mapper注解

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

Java代码

  1. @Mapper
  2. public****interface DemoMapper {
  3. @Insert(“insert into Demo(name) values(#{name})”)
  4. @Options(keyProperty=“id”,keyColumn=“id”,useGeneratedKeys=true)
  5. public****void save(Demo demo);
  6. }

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

(2)方式二:使用@MapperScan注解

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

Java代码

  1. @SpringBootApplication
  2. @MapperScan(“com.kfit.*.mapper”)
  3. public****class App {
  4. publicstaticvoid main(String[] args) {
  5. ​ SpringApplication.run(App.class, args);
  6. }
  7. }

或者:

Java代码

  1. @SpringBootApplication
  2. @MapperScan(“com.kfit.mapper”)
  3. public****class App {
  4. publicstaticvoid main(String[] args) {
  5. ​ SpringApplication.run(App.class, args);
  6. }
  7. }

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

使用@MapperScan注解多个包

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

Java代码

  1. @SpringBootApplication
  2. @MapperScan({“com.kfit.demo”,“com.kfit.user”})
  3. public****class App {
  4. publicstaticvoid main(String[] args) {
  5. ​ SpringApplication.run(App.class, args);
  6. }
  7. }

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

Java代码

  1. @SpringBootApplication
  2. @MapperScan({“com.kfit..mapper","org.kfit..mapper”})
  3. public****class App {
  4. publicstaticvoid main(String[] args) {
  5. ​ SpringApplication.run(App.class, args);
  6. }
  7. }

相关文章