MyBatis 分页插件 PageHelper-Dazer007

文章目录

  • MyBatis 分页插件 PageHelper-Dazer007
    • 1、使用方式
      • 1.1 原始PageHelper
      • 1.2 ruoyi框架封装PageHelper
      • 1.3 MyBaits-Plus自带分页,无需PageHeler
    • 2、作用原理
    • 3、数据方言实现
      • 3.1、MySqlDialect
      • 3.2、OracleDialect
      • 3.3、SqlServer2012Dialect
    • 3、数据方言实现

MyBatis作为目前流行的ORM框架,大大方便了日常开发。而对于分页查询,虽然可以通过SQL的limit语句实现,但是比较繁琐。而MyBatis PageHelper的出现,则解决了这一痛点。

参考1-腾讯云:Mybatis分页插件: pageHelper的使用及其原理解析、
参考2-官网-认真阅读:https://pagehelper.github.io/docs/howtouse/、
参考3-知乎:MyBatis之分页查询:MyBatis PageHelpe

MyBatis 分页插件 PageHelper-Dazer007

1、使用方式

PageHelper是一个物理分页的插件,根据Sql方言,执行不同的分页方法,可以放到service或者mapper查询之前,但是只对第一个查询有效;

1.1 原始PageHelper

   //使用原始的PageHelper分页方法
   //PageHelper必须紧跟service 或者 mapper,只对代码后面的第一个查询有效,切记
   PageHelper.startPage(pageNum, pageSize);
   List<VficWxSubscribeMsg> data =  vficWxSubscribeMsgMapper.getCurrentRecommendMsg();

1.2 ruoyi框架封装PageHelper

   //2020-2023涉疫项目若依(hesuan、yimiao)中大量使用了BaseController若依PageHelper封装的分页
   this.startPage();
   List<PreCheckDTO> list = queryService.getPreCheckList(vo);
   return this.getDataTable(list);

1.3 MyBaits-Plus自带分页,无需PageHeler

   //lflk、zyt、jhmy中全部使用MyBits-Plus自带分页,就不需要PageHelper了,自动分页,MyBits-Plu示例1
@DS("salver1")
@Mapper
@Repository
public interface BizLocationMapper extends BaseMapper<BizLocation> {
    /**
     * 自定义分页
     * com.baomidou.mybatisplus.core.metadata.page: 不需要处理,自动分页
     * paramVo: 对应使用:#{cm.locationId}取参
     */
    IPage<BizLocation> customizedPage(IPage<BizLocation> page,@Param(Constants.COLUMN_MAP)  BizLocation paramVo);
}
   //lflk、zyt、jhmy中全部使用MyBits-Plus自带分页,就不需要PageHelper了,自动分页,MyBits-Plu示例2
public interface GovLogsService extends IService<GovLogs> {
	IPage<GovLogs> customizePage(IPage<GovLogs> page, GovLogs param);
}

@Slf4j
@AllArgsConstructor
@Service
public class GovLogsServiceImpl extends ServiceImpl<GovLogsMapper, GovLogs>
 @Override
    public IPage<GovLogs> customizePage(IPage<GovLogs> page, GovLogs param) {
        return this.page(page, this.getQueryWrapper(param));
    }
    
    private LambdaQueryWrapper<GovLogs> getQueryWrapper(GovLogs param) {
        LambdaQueryWrapper<GovLogs> query = Wrappers.lambdaQuery();
        query.eq(Objects.nonNull(param.getLogId()), GovLogs::getLogId, param.getLogId());
        query.eq(Objects.nonNull(param.getType()), GovLogs::getType, param.getType());
        query.eq(Objects.nonNull(param.getMethod()), GovLogs::getMethod, param.getMethod());
        query.eq(Objects.nonNull(param.getIsSuccess()), GovLogs::getIsSuccess, param.getIsSuccess());
        query.eq(Objects.nonNull(param.getResponseCode()), GovLogs::getResponseCode, param.getResponseCode());
        query.likeRight(StringUtils.isNotEmpty(param.getUrl()), GovLogs::getUrl, param.getUrl());
        query.like(StringUtils.isNotEmpty(param.getRequest()), GovLogs::getRequest, param.getRequest());
        query.like(StringUtils.isNotEmpty(param.getResponse()), GovLogs::getResponse, param.getResponse());
        query.ge(Objects.nonNull(param.getBeginTime()), GovLogs::getCreateTime, param.getBeginTime());
        query.le(Objects.nonNull(param.getEndTime()), GovLogs::getCreateTime, param.getEndTime());
        query.orderByDesc(GovLogs::getCreateTime);
        return query;
    }
 }

2、作用原理

在上述代码的第一行代码设置分页参数后,
PageHelper 会把设置的分页参数封装到一个 Page 对象中并存储到一个 ThreadLocal中。
其中涉及到的关键源码有:PageMethod #startPage()、PageMethod #setLocalPage。

PageMethod
PageInterceptor
最后,让我们对 PageHelper 插件分页的原理做下总结:

  1. MvBatis 启动阶段、会解析配置文件、并将解析后的结果保存到一个 Configuration 对象中。其中,我们配置的插件,会被解析并保存到 Confiquration 对象的 InterceptorChain 对象中;
  2. MyBatis 的执行阶段,会先为当前的 executor 对象创建一个 JDK的动态代理对象,其中,动态代理类的关键实现就是调用插件的 intercept()。
  3. 在插件的 intercept)中,PageHelper 会先从 ThreadLocal 中获取参数的信息,然后在原始 SQL 的尾部拼接上 LMIT 分页语句,从而实现物理分页的效果。

3、数据方言实现

3.1、MySqlDialect

在原始SQL尾部添加分页参数

//com.github.pagehelper.dialect.helper.MySqlDialect
//com.baomidou.mybatisplus.extension.plugins.pagination.dialects.MySqlDialect 也有类似的实现

 @Override
  public String getPageSql(String sql, Page page, CacheKey pageKey) {
        StringBuilder sqlBuilder = new StringBuilder(sql.length() + 14);
        sqlBuilder.append(sql);
        if (page.getStartRow() == 0) {
            sqlBuilder.append("\n LIMIT ? ");
        } else {
            sqlBuilder.append("\n LIMIT ?, ? ");
        }
        return sqlBuilder.toString();
    }

3.2、OracleDialect

//com.github.pagehelper.dialect.helper.OracleDialect
//com.baomidou.mybatisplus.extension.plugins.pagination.dialects.Oracle12cDialect mybatisplus类似的方言实现
 @Override
 public String getPageSql(String sql, Page page, CacheKey pageKey) {
        StringBuilder sqlBuilder = new StringBuilder(sql.length() + 120);
        sqlBuilder.append("SELECT * FROM ( ");
        sqlBuilder.append(" SELECT TMP_PAGE.*, ROWNUM PAGEHELPER_ROW_ID FROM ( \n");
        sqlBuilder.append(sql);
        sqlBuilder.append("\n ) TMP_PAGE)");
        sqlBuilder.append(" WHERE PAGEHELPER_ROW_ID <= ? AND PAGEHELPER_ROW_ID > ?");
        return sqlBuilder.toString();
  }

3.3、SqlServer2012Dialect

//com.github.pagehelper.dialect.helper.SqlServer2012Dialect
//com.baomidou.mybatisplus.extension.plugins.pagination.dialects.SQLServerDialect mybatisplus中类似的方言实现
 @Override
    public String getPageSql(String sql, Page page, CacheKey pageKey) {
        StringBuilder sqlBuilder = new StringBuilder(sql.length() + 64);
        sqlBuilder.append(sql);
        sqlBuilder.append("\n OFFSET ? ROWS FETCH NEXT ? ROWS ONLY ");
        pageKey.update(page.getPageSize());
        return sqlBuilder.toString();
    }

3、数据方言实现

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Spring】Spring事务和事务传播机制

文章目录 什么是事务事务的操作Spring 中事务的实现Spring编程式事务Spring 声明式事务 TransactionalTransactional作用Transactional 详解rollbackFor事务隔离级别Spring 事务隔离级别Spring 事务传播机制 什么是事务 事务&#xff08;Transaction&#xff09;是一个程序中一…

嵌入式软件的设计模式与方法

思想有多远&#xff0c;我们就能走多远 4、状态与工作流类设计模式 4.1 状态与事件 行为随条件变化而改变&#xff0c;这里状态切换的模式也称为状态机。有限状态机 (Finite State Machine&#xff0c;FSM) 是由3 个主要元素组成的有向图: 状态、转换和动作。 状态是系统或者…

jsp教材管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 教材管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0&…

python常用的深度学习框架

目录 一&#xff1a;介绍 二&#xff1a;使用 Python中有几个非常受欢迎的深度学习框架&#xff0c;它们提供了构建和训练神经网络所需的各种工具和库。以下是一些最常用的Python深度学习框架&#xff1a; 一&#xff1a;介绍 TensorFlow&#xff1a;由Google开发的TensorF…

LeetCode-第171题-Excel表的序列号

1.题目描述 给你一个字符串 columnTitle &#xff0c;表示 Excel 表格中的列名称。返回 该列名称对应的列序号 。 例如&#xff1a; A -> 1 B -> 2 C -> 3 ... Z -> 26 AA -> 27 AB -> 28 ... 2.样例描述 3.思路描述 遍历时将每个字母与 A 做减法&…

python 动态数据 展示 ,数据是由51单片机发送过来的,温度传感器。

import tkinter as tk import randomimport seriallis[] for i in range(50):lis.append(i1) # 打开串行端口 ser serial.Serial(COM3, 9600) # 9600为波特率&#xff0c;根据实际情况进行调整# 初始化数据 lis [random.randint(15, 35) for _ in range(50)]def update_data…

jenkins 发布远程服务器并部署项目

安装参考另一个文章 配置maven 和 jdk 和 git 注意jdk的安装目录&#xff0c;是jenkins 安装所在服务器的jdk目录 注意maven的目录 是jenkins 安装所在服务器的maven目录 注意git的目录 是jenkins 安装所在服务器的 git 目录 安装 Publish Over SSH 插件 配置远程服务器 创…

信号系统之线性系统详解

1 线性系统 信号描述了一个参数如何随另一个参数变化。例如&#xff0c;电子电路中的电压随时间变化&#xff0c;或图像中随距离变化的亮度。系统是响应输入信号而产生输出信号的任何过程。如图中的框图所示。 有几个规则用于命名信号&#xff1a; 连续信号使用圆括号&#x…

Python tkinter (15) —— PhotoImage

本文主要介绍Python tkinter PhotoImage图像应用及示例。 系列文章 python tkinter窗口简单实现 Python tkinter (1) —— Label标签 Python tkinter (2) —— Button标签 Python tkinter (3) —— Entry标签 Python tkinter (4) —— Text控件 Python tkinter (5) 选项按…

22.HarmonyOS App(JAVA)位置布局PositionLayout使用方法

不常用 在PositionLayout中&#xff0c;子组件通过指定准确的x/y坐标值在屏幕上显示。(0, 0)为左上角&#xff1b;当向下或向右移动时&#xff0c;坐标值变大&#xff1b;允许组件之间互相重叠 布局方式 PositionLayout以坐标的形式控制组件的显示位置&#xff0c;允许组件相…

JVM 性能调优 - Java 虚拟机内存体系(1)

Java 虚拟机我们简称为 JVM&#xff08;Java Virtual Machine&#xff09;。 Java 虚拟机在执行 Java 程序的过程中&#xff0c;会管理几个不同的数据区域。如下图所示&#xff1a; 下面我会介绍这几个数据区的特点。 堆 堆区的几个特点&#xff1a; 线程共享。启动时创建堆…

【MATLAB源码-第131期】基于matlab的淘金优化算法(GRO)机器人栅格路径规划,输出做短路径图和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 淘金优化算法&#xff08;GoldRush Optimizer&#xff0c;简称GRO&#xff09;是一种启发式优化算法&#xff0c;它受到淘金过程的启发。在淘金过程中&#xff0c;淘金者在河流或矿区中寻找金矿&#xff0c;通过筛选沙砾来寻…

Django通过Json配置文件分配多个定时任务

def load_config():with open("rule.json", rb)as f:config json.load(f)return configdef job(task_name, config, time_interval):# ... 通过task_name判断进行操作if task_name get_data_times:passdef main():config load_config()for task_name, task_value…

SpringBoot多模块项目proguard混淆

SpringBoot多模块项目proguard混淆 前言整活项目目录混淆后的效果图混淆配置混淆配置规则keep相关通配符和关键字keep说明常见问题解决办法效果前言 proguard 是压缩、优化和混淆Java字节码文件的免费的工具。 它可以删除无用的类、字段、方法和属性。可以删除没用的注释,最大…

网络故障的排错思路

一、网络排错必备知识 1、网络通信的基础设备和其对应的OSI层次 在网络通信中&#xff0c;了解基础设备如交换机、三层交换机、路由器和防火墙以及它们在OSI七层模型中 的作用至关重要。对于网络管理员和工程师来说&#xff0c;深入了解这些设备在OSI模型中的位置和功能可 …

探索Gin框架:Golang Gin框架请求参数的获取

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站https://www.captainbed.cn/kitie。 前言 我们在专栏的前面几篇文章内讲解了Gin框架的路由配置&#xff0c;服务启动等内容。 专栏地址&…

为什么有的人渐渐不点外卖了?

​随着互联网的发展和普及&#xff0c;外卖行业也在近几年内得到了迅猛的发展&#xff0c;它方便快捷、节省时间的特点使得外卖成为了很多人生活的一部分。但是&#xff0c;随着时间的推移&#xff0c;越来越多的人开始减少点外卖的频率&#xff0c;这是为什么呢&#xff1f; 首…

npm修改镜像源

背景&#xff1a;切换npm镜像源是经常遇到的事&#xff0c;下面记录下具体操作命令 1. 打开终端运行"npm config get registry"命令来查看当前配置的镜像源 npm config get registry2. 修改成淘宝镜像源"https://registry.npmjs.org/" npm config set re…

编译原理与技术(三)——语法分析(二)自顶向下-递归下降

一、语法分析的两种方法 自顶向下&#xff08;Top-down&#xff09;&#xff1a; 针对输入串&#xff0c;从文法的开始符号出发&#xff0c;尝试根据产生式规则推导&#xff08;derive&#xff09;出该输入串。 从根部开始构造语法树。 自底向上&#xff08;Bottom-up&#…

鸿蒙踩坑合集

各位网络中的小伙们&#xff0c;关于鸿蒙的踩坑陆陆续续收集中&#xff0c;本文章会持续更新&#xff0c;希望对您有所帮助 1、预览视图无法正常加载 重新编译项目&#xff0c;点击刷新按钮&#xff0c;控制台提示Build task failed. Open the Run window to view details. 解…
最新文章