详细分析Mybatis与MybatisPlus中分页查询的差异(附Demo)

目录

  • 前言
  • [1. Mybatis](#1. Mybatis)
  • [2. MybatisPlus](#2. MybatisPlus)
  • [3. 实战](#3. 实战)

前言

更多的知识点推荐阅读:

  1. 【Java项目】实战CRUD的功能整理(持续更新)
  2. java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)

本章节主要以Demo为例,直奔主题,对于更多的基本知识可看我的框架架构

1. Mybatis

主要的逻辑从外往深走,具体如下:

  1. 创建一个Java类,实现业务逻辑,在该类中调用上述接口中的方法获取分页数据并构建PageResult对象返回
  2. 创建一个Java接口,声明两个方法,分别用于执行这两个查询语句
  3. 创建XML映射文件,定义两个查询语句,分别用于获取分页列表和总记录数

主体代码如下:

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.system.mapper.UserMapper">

    <select id="fetchCustomPageResults"
            resultType="com.example.system.model.UserModel" >
        SELECT * FROM users
        <where>
            <if test="criteria.name != null and criteria.name !=''">
                AND name LIKE CONCAT('%',#{criteria.name},'%')
            </if>
            <if test="criteria.createTime != null">
                AND create_time BETWEEN #{criteria.createTime[0]}, #{criteria.createTime[1]},
            </if>
            <if test="criteria.status != null">
                AND status = #{criteria.status}
            </if>
        </where>
        ORDER BY id DESC
        LIMIT #{criteria.pageNumber}, #{criteria.pageSize}
    </select>

    <select id="fetchCustomTotalCount" resultType="Long" >
        SELECT COUNT(1) FROM users
        <where>
            <if test="criteria.name != null and criteria.name !=''">
                AND name LIKE CONCAT('%',#{criteria.name},'%')
            </if>
            <if test="criteria.createTime != null">
                AND create_time BETWEEN #{criteria.createTime[0]}, #{criteria.createTime[1]},
            </if>
            <if test="criteria.status != null">
                AND status = #{criteria.status}
            </if>
        </where>
    </select>

</mapper>
java 复制代码
@Mapper
public interface CustomUserMapper extends BaseMapperX<UserModel> {

    /**
     * 获取自定义分页结果
     */
    List<UserModel> fetchCustomPageResults(@Param("criteria") UserCriteria criteria);

    /**
     * 获取自定义总记录数
     */
    Long fetchCustomTotalCount(@Param("criteria") UserCriteria criteria);

}

@Service
@Slf4j
public class CustomUserService {

    @Override
    public PageResult<UserModel> fetchCustomUserPage(UserCriteria criteria) {
        return new PageResult<>(
                userMapper.fetchCustomPageResults(criteria),
                userMapper.fetchCustomTotalCount(criteria)
        );
    }
}

对应实现类如下:

java 复制代码
@Service
@Slf4j
public class CustomUserServiceImpl implements CustomUserService{

    private final CustomUserMapper userMapper;

    @Autowired
    public CustomUserService(CustomUserMapper userMapper) {
        this.userMapper = userMapper;
    }

    @Override
    public PageResult<UserModel> fetchCustomUserPage(UserCriteria criteria) {
        return new PageResult<>(
                userMapper.fetchCustomPageResults(criteria),
                userMapper.fetchCustomTotalCount(criteria)
        );
    }
}

以上的Demo提供一个框架思路

2. MybatisPlus

具体代码如下:

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.system.mapper.AdminUserMapper">

    <select id="fetchCustomPageResults"
            resultType="com.example.system.model.UserModel" >
        SELECT * FROM users
        <where>
            <if test="criteria.name != null and criteria.name !=''">
                AND username LIKE CONCAT('%',#{criteria.name},'%')
            </if>
            <if test="criteria.createTime != null">
                AND create_time BETWEEN #{criteria.createTime[0]}, #{criteria.createTime[1]},
            </if>
            <if test="criteria.status != null">
                AND status = #{criteria.status}
            </if>
        </where>
        ORDER BY id DESC
    </select>

</mapper>
java 复制代码
@Mapper
public interface CustomAdminUserMapper extends BaseMapperX<UserModel> {

    IPage<UserModel> fetchCustomPageResults(IPage<UserModel> page, @Param("criteria") UserCriteria criteria);

}

其实现类如下:

java 复制代码
@Service
@Slf4j
public class CustomUserServiceImpl implements CustomUserService{

    private final CustomAdminUserMapper userMapper;

    @Autowired
    public CustomAdminUserService(CustomAdminUserMapper userMapper) {
        this.userMapper = userMapper;
    }

    @Override
    public PageResult<UserModel> fetchCustomUserPage(UserCriteria criteria) {
        // 必须使用 MyBatis Plus 的分页对象
        IPage<UserModel> page = new Page<>(criteria.getPageNo(), criteria.getPageSize());
        userMapper.fetchCustomPageResults(page, criteria);
        return new PageResult<>(page.getRecords(), page.getTotal());
    }
}

3. 实战

看Demo示例可能有些抽象,结合自身项目给一个示例

Controller类如下:

java 复制代码
@GetMapping("/listByOrderId")
@ApiOperationSupport(order = 8)
@ApiOperation(value = "分页", notes = "传入docheck")
public R<List<DoCheckVO>> list(Long orderId) {
	List<DoCheck> doChecks = docheckService.listByOrderId(orderId);
	return R.data(DocheckWrapper.build().listVO(doChecks));
}

对应的Service类如下:

java 复制代码
List<DoCheck> listByOrderId(Long orderId);

其中的实现类如下:

java 复制代码
@Override
public List<DoCheck> listByOrderId(Long orderId) {
	return docheckMapper.listByOrderId(orderId);
}

Mapper类如下:

java 复制代码
List<DoCheck> listByOrderId(Long orderId);

对应的Xml代码如下:

xml 复制代码
<select id="listByOrderId" resultType="org.springblade.equipment.entity.DoCheck">
    select * from equipment_check_order_docheck  where is_deleted = 0 and check_order_id=#{orderId}
</select>

其中xml的上文如下:

相关推荐
枣伊吕波11 分钟前
第六节第二部分:抽象类的应用-模板方法设计模式
android·java·设计模式
xinxiyinhe15 分钟前
内存泄漏与OOM崩溃根治方案:JVM与原生内存池差异化排查手册
java·开发语言·jvm
心向阳光的天域19 分钟前
黑马Java跟学.最新AI+若依框架项目开发(一)
java
what_201823 分钟前
分布式链路跟踪
java·运维·分布式
oliveira-time31 分钟前
ArrayList和LinkedList区别
java·开发语言
潮流coder34 分钟前
IntelliJ IDEA给Controller、Service、Mapper不同文件设置不同的文件头注释模板、Velocity模板引擎
java·ide·intellij-idea
码农飞哥41 分钟前
互联网大厂Java求职面试实战:Spring Boot与微服务场景深度解析
java·数据库·spring boot·安全·微服务·消息队列·互联网医疗
Akiiiira1 小时前
【日撸 Java 300行】Day 14(栈)
java·开发语言
猴子请来的逗比4891 小时前
tomcat与nginx之间实现多级代理
java·nginx·tomcat
一丝晨光1 小时前
数值溢出保护?数值溢出应该是多少?Swift如何让整数计算溢出不抛出异常?类型最大值和最小值?
java·javascript·c++·rust·go·c·swift