当前位置: 首页 > news >正文

Mybatis-Plus05(分页插件)

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

1. 添加配置类

@Configuration
@MapperScan("com.atguigu.mybatisplus.mapper")  //可以将主类中的注解移到此处
public class MybatisPlusConfig {@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new
PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}}

2. 测试

@Test
public void testPage(){
//设置分页参数,第一个是设置当前页,第二个是每页数量
Page<User> page = new Page<>(1, 3);
userMapper.selectPage(page, null);
//null表示不设置条件,查询所有
//获取分页数据
List<User> list = page.getRecords();
list.forEach(System.out::println);
System.out.println("当前页:"+page.getCurrent());
System.out.println("每页显示的条数:"+page.getSize());
System.out.println("总记录数:"+page.getTotal());
System.out.println("总页数:"+page.getPages());
System.out.println("是否有上一页:"+page.hasPrevious());
System.out.println("是否有下一页:"+page.hasNext());
}

请添加图片描述

结果:
获取分页的数据:
User(id=1, name=Jone, age=18, email=test1@baomidou.com, isdel=0)
User(id=3, name=Tom, age=28, email=test3@baomidou.com, isdel=0)
User(id=4, name=张五, age=21, email=test4@baomidou.com, isdel=0)

当前页:
1
每页显示的条数:
3
总记录数:
7
总页数:
3
是否有上一页:
false

是否有下一页:
true

3.xml自定义分页

  • 根据年龄查询用户列表,分页显示
  • @param page 分页对象 ,xml中可以从里面进行取值 ,传递参数 Page 即自动分页 ,必须放在第一位
  • @param age 年龄
@Repository
public interface UserMapper  extends BaseMapper<User> {Page<User> selectPageVo(@Param("page") Page<User> page,@Param("age") Integer age) ;
}

UserMapper.xml中编写SQL

<select id="selectPageVo" resultType="User">
SELECT id,user_name,age,email FROM user WHERE age > # {age}
</select>

因为有个resultType所以我们需要在application.yaml中的mybatis-pus上添加(实体类自己的包名字,这是我自己的,根据自己需求改)

type-aliases-package: com.qcby.springboot.model

测试:

@Test
public void testSelectPageVo(){
//设置分页参数
Page<User> page = new Page<>(1, 5);
userMapper.selectPageVo(page, 20);
//获取分页数据
List<User> list = page.getRecords();
list.forEach(System.out::println);
System.out.println("当前页:"+page.getCurrent());
System.out.println("每页显示的条数:"+page.getSize());
System.out.println("总记录数:"+page.getTotal());
System.out.println("总页数:"+page.getPages());
System.out.println("是否有上一页:"+page.hasPrevious());
System.out.println("是否有下一页:"+page.hasNext());
}

还有另一种的:可以直接使用querywrapper

@Test
public void test(){//设置分页参数Page<User> page=new Page<User>(1,3);QueryWrapper<User> queryWrapper=new QueryWrapper<>();queryWrapper.ge("age",20);userMapper.selectPage(page,queryWrapper);List<User> list=  page.getRecords();list.forEach(System.out::println);
http://www.lryc.cn/news/331588.html

相关文章:

  • python爬取B站视频
  • 深度学习500问——Chapter05: 卷积神经网络(CNN)(2)
  • 基于单片机的测时仪系统设计
  • 鸿蒙原生应用开发-网络管理Socket连接(三)
  • 【Java EE】关于Maven
  • 每日一题:C语言经典例题之反转数
  • RESTfull接口访问Elasticsearch
  • NoSQL之Redis
  • double二分(P3743 小鸟的设备)
  • 【独立开发前线】Vol.36 为什么从2023年开始,独立开发者越来越多了?
  • GPT4不限制使用次数了!GPT5即将推出了!
  • 物联网实战--入门篇之(六)嵌入式-WIFI驱动(ESP8266)
  • Java并发编程基础面试题详细总结
  • EKO / 砍树
  • Kafka面试宝典
  • Redis性能管理
  • 计算机网络:局域网的数据链路层
  • Linux常见命令简介
  • 34-SDK设计(下):IAM项目GoSDK设计和实现
  • 基于Matlab的血管图像增强算法,Matlab实现
  • LeetCode每日一题之专题一:双指针 ——复写零
  • Golang基础-9
  • Vue基础知识:路由的封装抽离,路由模块的封装抽离的好处是什么?,如何快速的引入组件,基于@指代src目录,从src目录出发找组件
  • 插入排序---算法
  • Vue3 Vite 整合组件脚手架笔记
  • 续二叉搜索树递归玩法
  • DDD 的四层领域模型是怎样的?包含哪些基础概念?
  • AI 在医疗保健领域的应用:技术、趋势和前景
  • SVG XML 格式定义图形入门介绍
  • MYSQL数据库的故障排除与优化