项目技术点-MybatisPlus 实现分页 | 学习笔记

简介: 快速学习 项目技术点-MybatisPlus 实现分页

开发者学堂课程【微服务+全栈在线教育实战项目演练(SpringCloud Alibaba+SpringBoot) 项目技术点-MybatisPlus 实现分页】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/667/detail/11274


项目技术点-MybatisPlus 实现分页


mp 做四类简单的查询

1.根据 id 查询数据

//根据 id 查询数据

User user=userMapper.selectById(serializable:1231115382920916994L) ;//进行修改

user.setAge(200);

userMapper.updateById(user);

2、通过多个 id 批量查询

@Test

public void testSelectBatchIds()

List<User> users=userMapper.selectBatchIds(Arrays.asList(1,2,3));

users.forEach(System.out::println);

代码:

//多个 id 批量查询

@Test

public void testSellectltDemo1()List<User>users=userMapper.selectBatchIds(Arrays.asList(1L,2L,3L));System.out.println(users);

3.简单的条件查询

注:通过 map 封装查询条件

@Test

public void testSelectByMap)

HashMap<String, Object>map=new HashMapo();

map.put("name","Helen");

map.put("age",18);

List<User> users = userMapper.selectByMap(map);

users.forEach(System.out::println);

注意:map 中的 key 对应的是数据库中的列名。例如数据库 user_jid,实体类是 userld,这时 map 的 key 需要填写user_jid

4、分页

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

(1) 第一步:创建配置类(分页插件)

此时可以删除主类中的@Mapperscan 扫描注解

/**

*分页插件

*/

@Bean

public PaginationInterceptor paginationInterceptor() {

return new PaginationInterceptor();

(2)第二步:编写分页代码,测试:最终通过 page 对象获取相关数据

@Test

public void testSelectPage()

Page<User> page.new Pageo(1,5)

userMapper.selectPage(page,null);

page.getRecords().forEach(System.out::println);

System.out.println(page.getCurrent());

System.out.println(page.getPages());

System.out.println(page.getSize());

System.out.println(page.getTotal());

System.out.println(page.hasNext());

System.out.println(page.hasPrevious());

(3)调用 mp 方法实现分页查询

//分页查询

@Test

public void testPage() {

//1创建 page 对象

//传入两个参数:当前页和每页显示记录数

Page<User> page = new Page<>(current:1, size:3);

//调用 mp 分页查询的方法

//调用 mp5分页查询过程中,底层封装

//把分页所有数据封装到 page 对象里面

userMapper.selectPage(page,wrapper:null);

//通过 page 对象获取分页数据

System.out.println(page.getCurrent();//当前页

System.out.println(page.getRecords()://每页数据1ist 集合

system.out.рrintln(page.getsize();//每页显示记录数 System.out.println(page.getTotal())://总记录数

System.out.println(page.getPages())://总页数

System.out.println(page.hasNext0);//下一页

System.out.println(page.hasPrevious0)://上一页

运行结果

Closing non transactional SqlSession[org.apache.ibatis.session.defaults.DefaultSqlSession@30c0d731]

1[User(id=1,name=Jone,age=18,email=test1@baomidou.com,createTime=null,updateTime=null,version=null),User(id=2,name)

True

false

相关文章
|
1月前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
98 4
|
7月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
96 0
|
7月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
5月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
565 15
|
8月前
|
XML SQL Java
十二、MyBatis分页插件
十二、MyBatis分页插件
216 17
|
8月前
|
监控 安全 数据库
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
数据库状态分为正常与异常两种情况。当出现异常时,首先查看告警列表确认问题(如实例无法连接),并尝试用数据库用户名和密码登录。若能登录,说明主实例故障已切换至备库;若无法登录或为单节点,则需进一步排查。接着检查监控项,若有数据表明主实例故障,无数据则可能是通信中断。随后检查主机上的服务是否存在,若存在但通信受限,需排查安全设置或网络;若服务不存在,可能因重启或断电导致,需手动启动相关服务。最终在YashanDB列表中确认状态恢复。
|
7月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
7月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
155 0
|
7月前
|
Oracle 关系型数据库 Java
|
8月前
|
Oracle 关系型数据库 MySQL
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
**Mybatis-Plus 自动分页配置问题简介** Mybatis-Plus 是 Mybatis 的增强工具,简化 CRUD 操作并适配多种数据库,包括 YashanDB。自动分页配置错误会导致应用开发受影响。解决方法:1. 配置 pagehelper 为 oracle 或 mysql;2. 设置分页拦截器为 oracle 或 mysql。确保返回设置后的对象。正确配置后可在 service 层使用 page 方法实现自动分页。