Mybatis分页

本文主要讲解Mybatis分页相关的技术分享,如果觉得不错的话,就点个赞吧。。。。
 

Mybatis分页主要有2种类型:

        一、物理分页:

                1、定义:

                        物理分页是在数据库层面进行的分页,即通过SQL语句直接从数据库中查询出需要的语句。

                2、优点:

                        只需要加载当前页的数据,不会占用过多的内存,适合数据量大的情况。

        二、内存分页:

                1、定义:

                        内存分页是将所有数据查询出来后,再在内存中进行分页。

                2、优点:

                        减轻数据库的负担,适合数据量小的情况。

                        如果数据量大,会占用大量的内存,严重甚至会导致内存溢出。

实现分页方法详解:

   一:物理分页的方法:

           1、使用LIMIT关键字:

                    这是最常见的物理分页方式,

                   原理:

                         通过在SQL语句中添加Limit子句来实现分页,

                   优缺点:

                        优点是简单直观,缺点是需要手动计算起始位置和结束位置。太低端,太Low,不推荐使用

                  实例:

#查询用户表第1页,一页有3条数据。这个需要开发人员自己计算,然后给到数据库
select * from user limit 1,3
          2、使用PageHelper插件:(推荐)

                   这是Mybatis提供的一个分页插件。

               原理:

                    a、当调用PageHelper.startPage()时,PageHelper会创建一个Page对象,并将其保存到ThreadLocal中。这个Page对象包含了分页信息,如页码和每页的数量。       

                     b、当调用Mapper的查询方法时,Mybatis会生成原始的SQL语句。在这个过程中,PageHelper会通过拦截器(Interceptor)拦截SQL语句的生成过程。               

                     c、 在拦截器中,PageHelper会从ThreadLocal中获取Page对象,然后根据Page对象中的分页信息,修改原始的SQL语句,添加LIMIT子句。

                     d、最后,Mybatis执行修改后的SQL语句,从数据库中查询出分页数据。

                 优缺点:

                     通过这种方式,PageHelper可以在不修改原始SQL语句的情况下,实现物理分页。但是需要注意的是:PageHelper只对其后的第一个SQL语句生效。

                 代码:
// 设置分页信息
PageHelper.startPage(page, size);
// 调用Mapper接口的查询方法
List<User> users = userMapper.selectAll();
                使用注意:

PageHelper的startPage方法只对紧跟着的第一个SQL语句生效,也就是说,如果我们在调用startPage方法之后执行了多个SQL语句,那么只有第一个SQL语句会进行分页查询,其他的SQL语句还是会查询所有的数据。

   使用pageHelper需要引入依赖:

<dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>最新版本</version>
</dependency>

二:内存分页的方法:


      1、使用Page对象:

             实现:

                实现有很多种,这里只写出一种。

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public List<User> getUsers(int page, int size) {// 查询所有数据List<User> allUsers = userMapper.selectAll();// 创建Page对象Page<User> userPage = new Page<>(page, size);// 设置数据userPage.setRecords(allUsers);// 获取当前页的数据return userPage.getRecords();}
}
       2、使用RowBounds对象:(推荐)
            原理:

                MyBatis在执行查询操作时,会检查是否传入了RowBounds对象,如果传入了,就会使用RowBounds中的offset和limit属性来对查询结果进行分页处理。具体的实现方式是,MyBatis会在生成的SQL语句中添加LIMIT和OFFSET关键字,然后将RowBounds中的offset和limit属性的值分别设置为LIMIT和OFFSET关键字的参数,从而实现分页查询。

           实现:

                a.  在Mapper接口的查询方法中,添加一个RowBounds类型的参数。

                b.在调用Mapper接口的查询方法时,创建一个RowBounds对象,并设置其offset和limit属性的值。

                c. MyBatis在执行查询操作时,会检查是否传入了RowBounds对象,如果传入了,就会使用        RowBounds中的offset和limit属性来对查询结果进行分页处理。

         代码:
//我们需要在Mapper接口中定义一个使用RowBounds的查询方法:
@Mapper
public interface UserMapper {List<User> selectAll(RowBounds rowBounds);
}//在Service层中,我们可以调用这个方法,并传入一个RowBounds对象来进行分页查询:
@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public List<User> getUsers(int page, int size) {// 创建RowBounds对象RowBounds rowBounds = new RowBounds((page - 1) * size, size);// 调用Mapper接口的查询方法return userMapper.selectAll(rowBounds);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/115806.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode1658. 将 x 减到 0 的最小操作数

题目链接&#xff1a;1658. 将 x 减到 0 的最小操作数 - 力扣&#xff08;LeetCode&#xff09; 知道滑动窗口&#xff0c;代码却写不出来 #define MIN(a ,b) ((a) < (b) ? (a) : (b))int minOperations(int* nums, int numsSize, int x) {int ans INT_MAX;int sum 0;f…

如何学会从产品经理角度去思考问题?

如何学会从产品经理角度去思考问题&#xff1f; 从产品经理的角度思考问题意味着你需要关注产品从构思到上市全过程中的各个方面&#xff0c;包括用户需求、市场趋势、设计、开发、测试、上市后的用户反馈等。以下是一些策略和方法&#xff0c;帮助你培养从产品经理角度思考问…

0基础学习PyFlink——使用PyFlink的Sink将结果输出到外部系统

在《0基础学习PyFlink——使用PyFlink的SQL进行字数统计》一文中&#xff0c;我们直接执行了Select查询操作&#xff0c;在终端中直接看到了查询结果。 select word, count(1) as count from source group by word; ------------------------------------------------------ |…

Python爬虫:ad广告引擎的模拟登录

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ &#x1f434;作者&#xff1a;秋无之地 &#x1f434;简介&#xff1a;CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作&#xff0c;主要擅长领域有&#xff1a;爬虫、后端、大数据…

Mybatis 相关模块以及设计模式分析

一、缓存模块 MyBatis作为一个强大的持久层框架&#xff0c;缓存是其必不可少的功能之一&#xff0c;Mybatis中的缓存分为一级缓存和二级缓存。但本质上是一样的&#xff0c;都是使用Cache接口实现的。缓存位于 org.apache.ibatis.cache包下。 通过结构我们能够发现Cache其实使…

螺杆支撑座是如何维持精度和稳定性的?

螺杆支撑座是机械设备中重要的支撑元件&#xff0c;主要用于支撑和固定螺杆&#xff0c;以确保其精度和稳定性&#xff0c;以下是螺杆支撑座在实际使用中的优势&#xff1a; 1、良好的耐腐蚀性&#xff1a;螺杆支撑座通常采用防腐蚀材料制造&#xff0c;能够抵抗各种腐蚀性介质…

linux安装visual studio code

下载 https://code.visualstudio.com/ 下载.deb文件 安装 假如文件被下载到了 /opt目录下 进入Opt目录&#xff0c;右键从当前目录打开终端。 输入下面的安装命令。 sudo apt-get install ./code_1.83.1-1696982868_amd64.deb 安装成功。 配置 打开 visual studio cod…

【蓝桥每日一题]-动态规划 (保姆级教程 篇11)#方格取数2.0 #传纸条

目录 题目&#xff1a;方格取数 思路&#xff1a; 题目&#xff1a;传纸条 思路&#xff1a; 题目&#xff1a;方格取数 &#xff08;跑两次&#xff09; 思路&#xff1a; 如果记录一种方案后再去跑另一个方案&#xff0c;影响因素太多了&#xff0c;所以两个方案要同时开…

手搭手Ajax经典基础案例省市联动

环境介绍 技术栈 springbootmybatis-plusmysql 软件 版本 mysql 8 IDEA IntelliJ IDEA 2022.2.1 JDK 1.8 Spring Boot 2.7.13 mybatis-plus 3.5.3.2 pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http:/…

分类预测 | MATLAB实现SSA-CNN-BiLSTM-Attention数据分类预测(SE注意力机制)

分类预测 | MATLAB实现SSA-CNN-BiLSTM-Attention数据分类预测&#xff08;SE注意力机制&#xff09; 目录 分类预测 | MATLAB实现SSA-CNN-BiLSTM-Attention数据分类预测&#xff08;SE注意力机制&#xff09;分类效果基本描述模型描述程序设计参考资料 分类效果 基本描述 1.MAT…

Java中的常量管理:接口还是枚举,您如何选择?

在企业项目开发中&#xff0c;我们经常会需要设计一些常量的定义&#xff0c;两种常见的方式用于常量管理&#xff1a;接口和枚举。他们分别适用于什么场景了&#xff1f; 使用接口管理常量 接口中的常量通常具有以下特点&#xff1a; 通过 public static final 修饰&#x…

认识哈希表和哈希表的实现

哈希函数的定义&#xff1a; out f(in) 1&#xff09;in -> ∞&#xff0c; out -> S 输入域是无穷的&#xff0c;输出域是有限的&#xff0c;也就是S域&#xff1b; 2&#xff09;相同的输入一定会得到相同的输出&#xff1b; 3&#xff09;不同的输入可能会有相同…

Swift 判断 A B 两个时间是不是同一天,A 是不是 B 的昨天

1. 今天要做这个效果&#xff08;在时间旁边显示今天&#xff0c;昨天&#xff09; 2. Preview 3. Code: // 添加 今天 昨天 func show_today_yesterday(d: Date Date()) -> String {let calendar Calendar.currentlet today: Date Date()if calendar.isDate(today, inS…

C++DAY50

源文件代码 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);if(!db.contains()){db QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName(&q…

用来生成二维矩阵的dcgan

有大量二维矩阵作为样本&#xff0c;为连续数据。数据具有空间连续性&#xff0c;因此用卷积网络&#xff0c;通过dcgan生成二维矩阵。因为是连续变量&#xff0c;因此损失采用nn.MSELoss()。 import torch import torch.nn as nn import torch.optim as optim import numpy a…

QTday05(TCP的服务端客户端通信)

实现聊天室功能 服务端代码&#xff1a; pro文件需要导入 network 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTcpServer>//服务端 #include <QTcpSocket>//客户端 #include <QList> #include <QMes…

超声波清洗机频率如何选择?高频和低频有什么区别

超声波清洗原理就是在清洗液中产生“空化效应”&#xff0c;即清洗液产生拉伸和压缩现象&#xff0c;清洗液拉伸时会产生大量微小气泡&#xff0c;清洗液压缩时气泡会被压碎破裂。这些气泡产生和破裂的局部压强可达到上千个大气压的冲击力&#xff0c;这种极强大的压力足以使得…

Leetcode 1089. 复写零

复写零 题目链接1089. 复写零 给你一个长度固定的整数数组 arr &#xff0c;请你将该数组中出现的每个零都复写一遍&#xff0c;并将其余的元素向右平移。 注意&#xff1a;请不要在超过该数组长度的位置写入元素。请对输入的数组 就地 进行上述修改&#xff0c;不要从函数返回…

网络协议--UDP:用户数据报协议

11.1 引言 UDP是一个简单的面向数据报的运输层协议&#xff1a;进程的每个输出操作都正好产生一个UDP数据报&#xff0c;并组装成一份待发送的IP数据报。这与面向流字符的协议不同&#xff0c;如TCP&#xff0c;应用程序产生的全体数据与真正发送的单个IP数据报可能没有什么联…

并查集学习笔记

在一些有 n n n 个元素的集合应用问题中&#xff0c;我们通常是在开始时让每个元素构成一个单元素的集合&#xff0c;我们通常是在开始时让每个元素构成一个单元素的集合&#xff0c;然后按一定顺序将属于同一族的元素所在的集合合并&#xff0c;期间要反复查找一个元素在哪个…