MyBatis-Plus查询:批量、条件、分页查询的实现

MyBatis-Plus在MyBatis的基础上只做增强,不做改变,目的是为了简化开发,提高效率。本专栏六篇文章围绕MyBatis-Plus的常用技术点,结合springboot,实现了对数据库记录的CRUD操作,其他文章请参考:

  • 《MyBatis-Plus入门案例:查询数据库中所有记录》
  • 《MyBatis-Plus添加:常用主键策略的分析及实现》
  • 《MyBatis-Plus更新:自动填充与乐观锁的实现》
  • 《MyBatis-Plus查询:批量、条件、分页查询的实现》
  • 《MyBatis-Plus删除:物理删除与逻辑删除的实现》
  • 《MyBatis-Plus高级查询:条件构造器的实现》

作者:Hudie
个人公众号/CSDN博客:编程一只蝶
项目已开源至gitee:https://gitee.com/guo-qianliang/mybatis-plus-test
项目已开源至github:https://github.com/Guoqianliang/mybatis-plus-test


一、MyBatis-Plus实现批量查询

MyBatis-Plus的selectBatchIds方法完成了动态sql的foreach的功能,需要传入一个集合作为批量id的容器,可通过Arrays的asList()方法直接填入。

    // 多个id批量查询
    @Test
    public void testSelect01() {
        List users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
        System.out.println(users);
    }

查询结果:


批量查询的结果

二、MyBatis-Plus实现条件查询

通过map封装查询条件时,key对应数据库中的列名。如:数据库user_id,实体类是userId,这时map的key需要填写user_id。

    // 简单条件查询:查询出name=Tom & age=28 的用户信息
    @Test
    public void testSelect02() {
        Map columnMap = new HashMap<>();
        columnMap.put("name", "Tom");
        columnMap.put("age", "28");
        List users = userMapper.selectByMap(columnMap);
        System.out.println(users);
    }

查询结果:


条件查询的结果

实际上通过map封装查询条件的方式很少使用,后面文章中讲到的条件构造器才是经常使用的方法,这里作为了解即可

三、MyBatis-Plus实现分页查询

MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能,具体步骤如下:

步骤1:配置分页插件

在配置类中配置分页插件。

@Configuration
@MapperScan("com.gql.mybatisplustest.mapper")
public class MpConfig {
    /**
     * 分页插件
     */
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }

}

步骤2:编写分页代码

分页的所有数据都在userPage对象中封装着,所以可以调用userPage对象的一系列方法对分页数据进行操作。

 /**
     * 分页查询
     * new Page(current,size):
     *      current:当前页
     *      size:   每页记录数
     */
    @Test
    public void testSelectPage() {
        Page page = new Page(1, 3);
        Page userPage = userMapper.selectPage(page, null);
        // 分页的所有数据都在userPage对象中封装着
        // 获取总页数
        long pages = userPage.getPages();
        // 获取当前页
        long current = userPage.getCurrent();
        // 获取当前页数据集合
        List records = userPage.getRecords();
        // 获取总记录数
        long total = userPage.getTotal();
        // 当前页是否有下一页
        boolean hasNext = userPage.hasNext();
        // 当前页是否有上一页
        boolean hasPrevious = userPage.hasPrevious();

        System.out.println("总页数pages=" + pages);
        System.out.println("当前页current=" + current);
        System.out.println("当前页数据集合records=" + records);
        System.out.println("总记录数total=" + total);
        System.out.println("是否有下一页hasNext=" + hasNext);
        System.out.println("是否有上一页hasPrevious=" + hasPrevious);
    }

测试

当前数据库的user表中有8条记录,设置当前页数为1,每页记录数为3。


当前数据库中有8条记录

执行后的代码如下:


分页查询的结果

至此,批量查询、条件查询、分页查询都实现完成了。

你可能感兴趣的:(MyBatis-Plus查询:批量、条件、分页查询的实现)