大家好,又见面了,我是你们的朋友全栈君。
需求缘起:
在之前的文章中,我们定义DemoMapper类,但是并没有在该类上定义类似@Service或者@Controller之类的注解,那么为什么可以被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);
- }
- }
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/131529.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...