SpringBoot快速整合通用Mapper的示例代码

 更新时间:2022年07月11日 09:24:38   作者:小码code  
后端业务开发,每个表都要用到单表的 增删改查 等通用方法,而配置了通用Mapper可以极大的方便使用Mybatis单表的增删改查操作,这篇文章主要介绍了SpringBoot快速整合通用Mapper,需要的朋友可以参考下

前言

后端业务开发,每个表都要用到单表的 增删改查 等通用方法,而配置了通用Mapper可以极大的方便使用Mybatis单表的增删改查操作。

通用mapper配置

1、添加 maven :

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--通用mapper-->
<dependency>
  <groupId>tk.mybatis</groupId>
  <artifactId>mapper-spring-boot-starter</artifactId>
  <version>2.1.5</version>
</dependency>
<!-- pagehelp -->
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper-spring-boot-starter</artifactId>
  <version>1.2.3</version>
</dependency>

2、 Application 启动文件添加 MapperScan 注解

在springboot启动类添加 tk.mybatis 包下 MapperScan 注解

import tk.mybatis.spring.annotation.MapperScan;
@SpringBootApplication
@MapperScan("com.springboot.dao")
public class Application extends SpringBootServletInitializer {
	public static void main(String[] args) {
		SpringApplication.run(Application.class, args);
	}
}

其中 com.springboot.dao 是 dao 层的路径。

3、 Model 添加注解

添加 Table 注解和 Id 注解,

Table
id

例如下方的 User 实体:

@Table(name = "t_user")
public class User {
    //主键
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)//自增
    private Integer id;  
}

4、创建 MyMapper

import tk.mybatis.mapper.common.IdsMapper;
import tk.mybatis.mapper.common.Mapper;
public interface MyMapper<T> extends Mapper<T>, IdsMapper<T> {
}

需要实现的通用接口都写在 MyMapper 的继承类中,该类的包不能被 MapperScan 扫描到。

Mapper<T>
IdsMapper<T>

5、每个 dao 继承步骤4的 MyMapper

例如 UserDao 继承 MyMapper<User> :

public interface UserDao extends MyMapper<User> {
}

通用service

上面配置只是调用dao层可以有默认的增删改查的方法,还是要在对应的service添加增删查改,所以需要写一个通用service,把公共的方法都抽象到一个基础方法中。

BaseService.java 接口:

public interface BaseService<T> {
    /**
     * 查询所有
     *
     * @return 返回所有数据
     */
    List<T> selectAll();
    /**
     * 查询数据数量
     * @return
     */
    int selectCount();
    /**
     * 添加
     *
     * @param t   实体
     *
     * @return
     */
    int save(T t);
    /**
     * 修改
     *
     * @param t
     *            实体
     * @return
     */
    int updateByPrimaryKey(T t);
    /**
     * 根据主键删除
     *
     * @param t   主键
     *
     * @return
     */
    int deleteByPrimaryKey(int t);
}

BaseServiceImpl 实现类:

public class BaseServiceImpl<T> implements BaseService<T> {
    @Autowired
    private MyMapper<T> mapper;
    @Override
    public List<T> selectAll() {
        return mapper.selectAll();
    }
    @Override
    public int selectCount() {
        return mapper.selectCount(null);
    }
    @Override
    public int save(T t) {
        return mapper.insert(t);
    }
    @Override
    public int updateByPrimaryKey(T t) {
        return mapper.updateByPrimaryKey(t);
    }
    @Override
    public int deleteByPrimaryKey(int t) {
        return mapper.deleteByPrimaryKey(t);
    }
}

所有的 service 和 serviceImpl 都分别继承 BaseService 和 BaseServiceImpl ,例如 UserService 和 UserServiceImpl 分别继承 BaseService 和 BaseServiceImpl :

public interface UserService extends BaseService<User>{
}
@Service
public class UserServiceImpl extends BaseServiceImpl<User> implements UserService{
}

配置完成之后,在对应的 controller 调用,比如 UserController :

@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserService userService;
    @PostMapping("/add")
    public Object add(User user) {
        userService.save(user);
        return null;
    }
    @PostMapping("/delete")
    public Object delete(@RequestParam Integer id) {
        userService.deleteByPrimaryKey(id);
        return null;
    }
    @PostMapping("/update")
    public Object update(User user) {
        userService.updateByPrimaryKey(user);
        return null;
    }
    @GetMapping("/detail")
    public User detail(@RequestParam Integer id) {
        User user = userService.selectById(id);
         return user;
    }
    @GetMapping("/list")
    public List<User> list() {
       List<User> list = userService.list();
       return list;
    }
}

总结

通用mapper:

  • 创建SpringBoot启动文件添加 MapperScan ,扫描 dao 层的包。
  • 创建 MyMapper<T> 接口,根据自己需求继承要用的接口,比如 Mapper<T> 。
  • 每个dao接口继承 MyMapper<T> 接口。

通用service

  • 创建 BaseService 接口。
  • BaseServiceImpl 实现类,调用 MyMapper<T> 实现增删改查方法。
  • 每个 service 接口和 service 实现类分别继承 BaseService 接口和 BaseServiceImpl 实现类。
  • 每个 controller 就能调用通用方法。

遇到的问题

1、启动报错

required a bean of type 'com.jeremy.data.utils.MyMapper' that could not be found.

没有找到 MyMapper 对应的 bean ,无法注入。

解决方案:

1、 SpringBoot 启动文件添加 MapperScan 注解。

2、每个 dao 接口都要继承 MyMapper 。

以上两个步骤 缺一不可 。

github源码

https://github.com/jeremylai7/springboot-bootstrap

到此这篇关于SpringBoot快速整合通用Mapper的文章就介绍到这了,更多相关SpringBoot整合Mapper内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot启动时如何通过启动参数指定logback的位置

    SpringBoot启动时如何通过启动参数指定logback的位置

    这篇文章主要介绍了SpringBoot启动时如何通过启动参数指定logback的位置,在spring boot中,使用logback配置的方式常用的有两种,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • JavaSwing FlowLayout 流式布局的实现

    JavaSwing FlowLayout 流式布局的实现

    这篇文章主要介绍了JavaSwing FlowLayout 流式布局的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • Java线程的控制详解

    Java线程的控制详解

    这篇文章主要介绍了Java中的join线程、后台线程、线程睡眠、线程让步以及线程的优先级,非常的详细,希望能对大家有所帮助
    2014-10-10
  • 浅谈MyBatis中@MapKey的妙用

    浅谈MyBatis中@MapKey的妙用

    这篇文章主要介绍了MyBatis中@MapKey的妙用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • SpringBoot配置使用H2数据库的简单教程

    SpringBoot配置使用H2数据库的简单教程

    H2是一个Java编写的关系型数据库,它可以被嵌入Java应用程序中使用,或者作为一个单独的数据库服务器运行。本文将介绍SpringBoot如何配置使用H2数据库
    2021-05-05
  • Java 中的静态字段和静态方法 

    Java 中的静态字段和静态方法 

    这篇文章主要介绍了Java中的静态字段和静态方法,文章围绕Java 静态方法展开详细内容,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-03-03
  • Mysql中备份表的多种方法

    Mysql中备份表的多种方法

    本文给大家分享Mysql中备份表的四种方法,第一种方式是小表的备份,第二种是对整个数据库的备份与恢复,第三种是对某个数据表进行备份,每种方式给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2022-11-11
  • java输出镂空金字塔实现案例

    java输出镂空金字塔实现案例

    小编最近接到领导安排,要求根据用户输入,打印出相应层数的镂空金字塔效果,本文分步骤通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2021-09-09
  • 如何解决Maven无法拉取SNAPSHOT依赖问题

    如何解决Maven无法拉取SNAPSHOT依赖问题

    在使用Maven管理项目时,可能会遇到无法拉取SNAPSHOT版本依赖的问题,这通常是因为Maven默认不支持直接拉取SNAPSHOT版本,遇到这样的问题,可以通过在项目的pom.xml文件中添加<repositories>标签,并配置启用SNAPSHOT的仓库地址来解决
    2024-10-10
  • Java使用cxf发布及调用webservice接口的方法详解

    Java使用cxf发布及调用webservice接口的方法详解

    今天小编就为大家分享一篇关于Java使用CXF发布及调用WebService接口的方法,文中通过代码示例给大家介绍的非常详细,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2023-08-08

最新评论