• 四、MyBatis-Plus 查询


    1、查询

    1.1 通过多个id批量查询

    完成了动态sql的foreach的功能

    //多个id批量查询
    @Test
    public void testSelect1() {
        List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
        System.out.println(users);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    1.2 简单的条件查询

    通过map封装查询条件

    注意: map中的key对应数据库中的列名。如:数据库user_id,实体类是userId,这时map的key需要填写user_id

    //简单条件查询
    @Test
    public void testSelect2() {
        Map<String, Object> columnMap = new HashMap<>();
        columnMap.put("name","Jack");
        columnMap.put("age",20);
        List<User> users = userMapper.selectByMap(columnMap);
        System.out.println(users);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    2、分页

    2.1 分页插件

    MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能

    2.1.1 添加分页插件

    配置类中添加@Bean配置

    /**
     * 分页插件
     */
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.1.2 测试selectPage分页

    测试:最终通过page对象获取相关数据

    //分页查询
    @Test
    public void testSelectPage() {
        Page<User> page = new Page(1,3);
        Page<User> userPage = userMapper.selectPage(page, null);
        //返回对象得到分页所有数据
        long pages = userPage.getPages(); //总页数
        long current = userPage.getCurrent(); //当前页
        List<User> records = userPage.getRecords(); //查询数据集合
        long total = userPage.getTotal(); //总记录数
        boolean hasNext = userPage.hasNext();  //下一页
        boolean hasPrevious = userPage.hasPrevious(); //上一页
    
        System.out.println(pages);
        System.out.println(current);
        System.out.println(records);
        System.out.println(total);
        System.out.println(hasNext);
        System.out.println(hasPrevious);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    2.2 测试selectMapsPage分页

    当指定了特定的查询列时,希望分页结果列表只返回被查询的列,而不是很多null值

    测试selectMapsPage分页:结果集是Map

    @Test
    public void testSelectMapsPage() {
    //Page不需要泛型
    Page<Map<String, Object>> page = newPage<>(1, 5);
    Page<Map<String, Object>> pageParam = userMapper.selectMapsPage(page, null);
    List<Map<String, Object>> records = pageParam.getRecords();
    records.forEach(System.out::println);
    System.out.println(pageParam.getCurrent());
    System.out.println(pageParam.getPages());
    System.out.println(pageParam.getSize());
    System.out.println(pageParam.getTotal());
    System.out.println(pageParam.hasNext());
    System.out.println(pageParam.hasPrevious());
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    前端面试题之JS系类
    2022年9月2日:面向初学者的 web 开发--使用 JavaScript 制定决策
    【线性代数及其应用 —— 第一章 线性代数中的线性方程组】-1.线性方程组
    续集来了!我让 GPT-4 用 Laf 三分钟写了个完整的待办事项 App
    Vscode中快速生成代码的方式
    start()方法源码分析
    安全架构设计理论与实践
    第七章 指针
    【LeetCode】54. 螺旋矩阵
    JDY-16 蓝牙4.2模块串口测试方法
  • 原文地址:https://blog.csdn.net/qq_43102730/article/details/126338945