MyBatis中的@Mapper注解 @Mappe與@MapperScan關系


從mybatis3.4.0開始加入了@Mapper注解,目的就是為了不再寫mapper映射文件

 

現在項目中的配置

public interface DemoMapper{
int deleteByPrimaryKey(Integer id);
}


@MapperScan("com.mapper")
public class DlxRrsApplication {
}

原因:

     我們定義DemoMapper類,但是並沒有在該類上定義類似@Service或者@Mapper之類的注解,那么為什么可以被Spring管理呢?

 

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

       為了讓DemoMapper能夠讓別的類進行引用,我們可以在DemMapper類上添加@Mapper注解:

Java代碼  
@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類都需要添加此注解,麻煩。

 

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

       通過使用@MapperScan可以指定要掃描的Mapper類的包的路徑,比如:

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

或者:

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

       可以根據包的結構指定不同的表達式。

 

使用@MapperScan注解多個包

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

Java代碼  
@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主程序可以掃描的包或者子包下面,可以使用如下方式進行配置:

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM