MyBatis 您所在的位置:网站首页 bootstrap怎么实现分页 MyBatis

MyBatis

#MyBatis| 来源: 网络整理| 查看: 265

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实现条件查询三、MyBatis-Plus实现分页查询步骤1:配置分页插件步骤2:编写分页代码测试

一、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条记录 执行后的代码如下: 分页查询的结果 至此,批量查询、条件查询、分页查询都实现完成了。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有