⼿写分页sql_MyBatis-Plus分页查询以及⾃定义sql分页的实现⼀、引⾔
分页查询每个⼈程序猿⼏乎都使⽤过,但是有部分同学不懂什么是物理分页和逻辑分页。
物理分页:相当于执⾏了limit分页语句,返回部分数据。物理分页只返回部分数据占⽤内存⼩,能够获取数据库最新的状态,实施性⽐较强,⼀般适⽤于数据量⽐较⼤,数据更新⽐较频繁的场景。
逻辑分页:⼀次性把全部的数据取出来,通过程序进⾏筛选数据。如果数据量⼤的情况下会消耗⼤量的内存,由于逻辑分页只需要读取数据库⼀次,不能获取数据库最新状态,实施性⽐较差,适⽤于数据量⼩,数据稳定的场合。
那么MP中的物理分页怎么实现呢? 往下看往下看
⼆、配置
创建MybatisPlusConfig配置类,需要配置分页插件,⼩编使⽤的Spring boot配置⽅式。
/**
* @Auther: IT
* @Date: 2019/6/12 15:06
* @Description: MybatisPlus配置类
*/
@Configuration
public class MyBatisPlusConfig {
/**
* 分页插件
* @return
*/
@Bean
public PaginationInterceptor paginationInterceptor() {
return new PaginationInterceptor();
}
}
三、具体分页实现
MP的Wrapper提供了两种分页查询的⽅式,源码如下:
/**
* 根据 entity 条件,查询全部记录(并翻页)
*
* @param page 分页查询条件(可以为 RowBounds.DEFAULT)
* @param queryWrapper 实体对象封装操作类(可以为 null)
*/
分页查询插件
IPage selectPage(IPage page, @Param(Constants.WRAPPER) Wrapper queryWrapper);
/**
* 根据 Wrapper 条件,查询全部记录(并翻页)
*
* @param page 分页查询条件
* @param queryWrapper 实体对象封装操作类
*/
IPage> selectMapsPage(IPage page, @Param(Constants.WRAPPER) Wrapper queryWrapper);
可见两个分页⽅法参数都是⼀致的,只是返回参数略有不同,具体选择根据实际业务为准。
/**
* 分页查询
*/
@Test
public void selectByPage() {
QueryWrapper wrapper = new QueryWrapper();
wrapper.like("name", "⾬").lt("age", 40);
Page page = new Page<>(1,2);
//IPage userIPage = userMapper.selectPage(page, wrapper);
IPage> mapIPage = userMapper.selectMapsPage(page, wrapper);
System.out.println("总页数"+Pages());
System.out.println("总记录数"+Total());
List> records = Records();
records.forEach(System.out::println);
}
以上分页查询执⾏sql如下,先是查询了⼀次总记录数,然后在查询的数据。
DEBUG==> Preparing: SELECT COUNT(1) FROM user WHERE name LIKE ? AND age < ?
DEBUG==> Parameters: %⾬%(String), 40(Integer)
TRACE<== Columns: COUNT(1)
TRACE<== Row: 2
DEBUG==> Preparing: SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ? LIMIT ?,?
DEBUG==> Parameters: %⾬%(String), 40(Integer), 0(Long), 2(Long)
TRACE<== Columns: id, name, age, email, manager_id, create_time
TRACE<== Row: 2, 张⾬琪, 31, zjq@baomidou, 1088248166370832385, 2019-01-14 09:15:15
TRACE<== Row: 3, 刘红⾬, 31, lhm@baomidou, 1088248166370832385, 2019-01-14 09:48:16
DEBUG<== Total: 2
总页数1
总记录数2
现在我们有需求只要查询数据即可, 不关⼼总记录数等,如果使⽤默认的⽅式就消耗不必要的性能。那么解决办法也是很简单的,只需要在创建page对象时传⼊第三个参数为false即可。
Page page = new Page<>(1,2,false);
四、⾃定义sql分页查询
有时候查询的数据难免会出现多表连接查询,或者是⼀些复杂的sql语句,但是这些语句也是需要⽀持分页查询的,
先定义查询接⼝,第⼀个参数要是分页的参数,⼩编这⾥演⽰就写简单的sql。
步骤⼀:在mapper⽂件中,编写对应的分页查询接⼝。
步骤⼆:在xml中编写对应的sql语句,⼩编这⾥演⽰的 “${ew.customSqlSegment}”,这个是如果你想⾃定义的sql语句,也想使⽤wrapper查询条件构造器,则需要在mapper接⼝中添加参数,以及xml中也要有固定。
/**
* ⾃定义sql分页
* @param page
* @param queryWrapper 看这⾥看这⾥,如果⾃定义的⽅法中需要⽤到wrapper查询条件,需要这样写
* @return
*/
IPage selectMyPage(IPage page, @Param(Constants.WRAPPER) Wrapper queryWrapper);
SELECT * FROM user ${ew.customSqlSegment}
/**
* ⾃定义sql分页查询
*/
@Test
public void selectByMyPage() {
QueryWrapper wrapper = new QueryWrapper();
wrapper.like("name", "⾬").lt("age", 40);
Page page = new Page<>(1,2);
IPage mapIPage = userMapper.selectMyPage(page, wrapper);
System.out.println("总页数"+Pages());
System.out.println("总记录数"+Total());
List records = Records();
records.forEach(System.out::println);
}
五、多表sql分页查询
看评论有⼩伙伴反馈多表连接查询怎么分页,其实道理都是⼀样的。
⼩编以简单的为主,sql如下: his_ipd_encounter、his_user 两张表
alname from his_ipd_encounter e, his_user u where e.his_uid = u.his_uid mapepr如下:需要传⼊分页的参数,返回的类型也需要是分页对象
/**
*
* ⽤户 Mapper 接⼝
*
*
* @author IT
* @since 2019-06-14
*/
public interface UserMapper extends MyMapper {
/**
* 多表查询分页
* @param page
* @return
*/
IPage selectByHisName(IPage page);
}
测试如下:通过查看⽇志,执⾏的sql加了分页条件的。
@Test
public void select(){
// 创建分页参数
Page page = new Page<>(1,2);
IPage result = userMapper.selectByHisName(page);
// 获取数据
List records = Records();
records.forEach(System.out::println);
System.out.println("总页数 = "+ Pages());
}
ARNWarn: Could not find @TableId in Class: del.HisUser. INFOStarted UserMapperTest in 2.428 seconds (JVM running for 2.959)
alname from his_ipd_encounter e, his_user u where e.his_uid = u.his_uid
DEBUG==> Preparing: SELECT COUNT(1) FROM his_ipd_encounter e, his_user u WHERE e.his_uid = u.his_uid
DEBUG==> Parameters:
TRACE<== Columns: COUNT(1)
TRACE<== Row: 117
DEBUG==> Preparing: alname from his_ipd_encounter e, his_user u where e.his_uid = u.
his_uid LIMIT ?,? DEBUG==> Parameters: 0(Long), 2(Long)
TRACE<== Columns: realname
TRACE<== Row: 胡伯云
TRACE<== Row: 安元慧
DEBUG<== Total: 2
Time:20 ms - ID:ample.demo.mapper.UserMapper.selectByHisName
Execute SQL:
ine.wrapper.PreparedStatementWrapper@61bcbcce
胡伯云
安元慧
总页数 = 59
到此这篇关于MyBatis-Plus 分页查询以及⾃定义sql分页的实现的⽂章就介绍到这了,更多相关MyBatis-Plus ⾃定义sql分页内容请搜索脚本之家以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持脚本之家!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论