MyBatis-Plus 查询操作

一、查询

1.1、普通查询

在这里插入图片描述

    /**
     * 普通查询
     */
    @Test
    public void selectById() {
        User user = userMapper.selectById(1412963147760857089L);
        System.out.println(user);
    }

查询结果:
在这里插入图片描述

1.2、通过多个ID批量查询

在这里插入图片描述

   //多个id批量查询
    @Test
    public void testSelectByIds(){
        List<User> users = userMapper.selectBatchIds(Arrays.asList(1412963147760857089L,1413086639927959553L,1413087102014337026L));
        System.out.println(users);
    }

查询结果
在这里插入图片描述

1.3、简单条件查询

在这里插入图片描述

    //简单条件查询
    @Test
    public void selectSimpleTerm(){
        Map<String,Object> columnMap = new HashMap<>();
        columnMap.put("name","lucyYY");
        columnMap.put("age",20);
        List<User> users = userMapper.selectByMap(columnMap);
        System.out.println(users);
    }

查询结果
在这里插入图片描述

二、分页

2.1、分页插件

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

2.2、添加分页插件

配置类中添加@Bean配置:
在这里插入图片描述

    /**
     * 分页查询插件
     */
    @Bean
    public PaginationInterceptor paginationInterceptor(){
        return new PaginationInterceptor();
    }

2.3、测试selectPage分页

通过page对象获取相关数据:

    //分页查询
    @Test
    public void testSelectPage(){
        Page<User> page = new Page(2,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);
    }

查询结果
在这里插入图片描述

2.4、测试selectMapPage分页

当指定了特定的查询列时,希望分页结果列表只返回被查询的列,而不是很多null值。这时就可以测试selectMapsPage分页:结果集是Map。

    //根据特定条件查询结果
    @Test
    public void testSelectMapPage(){

        Page<Map<String,Object>> page = new Page<>(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
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值