MyBatis-Plus查询:批量、条件、分页查询的实现
2021-04-09 本文已影响0人
编程一只蝶
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<User> 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<String, Object> columnMap = new HashMap<>();
columnMap.put("name", "Tom");
columnMap.put("age", "28");
List<User> 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<User> page = new Page(1, 3);
Page<User> userPage = userMapper.selectPage(page, null);
// 分页的所有数据都在userPage对象中封装着
// 获取总页数
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=" + 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条记录
执行后的代码如下:
分页查询的结果
至此,批量查询、条件查询、分页查询都实现完成了。