SQL_CALC_FOUND_ROWS 和 FOUND_ROWS()实现对复杂sql实现分页与总条数查询

devtools/2024/9/23 0:24:38/

需求

java">ReturnResult result = new ReturnResult();
try {List<Map> forList = (List<Map>) dao.findForList("Mapper.getList", map);int count = (int) dao.findForObject("Mapper.getCount", map);result.setData(forList);result.setCode(0);result.setFlag(true);result.setCount(count);
} catch (Exception e) {result.setCode(0);result.setMessage(e.getMessage());result.setFlag(false);
}
return result;

以上代码运行速度缓慢,当数据量过大时,运行时间超过20秒。优化运行速度。

思路

这段代码看起来逻辑非常简通过dao调用了两次Mapper中的SQL语句,第一次通过map将条件及页码传入,查询出对应页码的数据。
第二次将sql中的limit去除,实现查询全部数据。
首先使用explain查看语句是否走索引。经测试sql有部分条件没有索引,将索引添加完毕后速度有了质的提高。
但查看sql语句,发现两段调用sql几乎相同,运行时间也相同,java程序顺序执行,及执行时间翻倍。使用SQL_CALC_FOUND_ROWSFOUND_ROWS()可以解决该问题。

使用及完整代码

利用 SQL_CALC_FOUND_ROWSFOUND_ROWS()关键字。以下是具体的 SQL 查询方法:

  1. 使用 SQL_CALC_FOUND_ROWSSQL 查询

    sql">SELECT SQL_CALC_FOUND_ROWS *
    FROM table
    WHERE 查询条件
    LIMIT 页码, 条数;
    

·*·代表需要查询出的字段。
2. 使用FOUND_ROWS()获取总条数

sql">   SELECT FOUND_ROWS();

SQL_CALC_FOUND_ROWS 会计算符合条件的总行数,而不受 LIMIT 的影响。FOUND_ROWS() 会返回上一个查询的结果总数。

Java 代码实现

java">ReturnResult result = new ReturnResult();
try {// 获取分页数据List<Map> forList = (List<Map>) dao.findForList("Mapper.getList", map);// 获取总条数int count = (int) dao.findForObject("Mapper.getCount");result.setData(forList);result.setCode(0);result.setFlag(true);result.setCount(count);
} catch (Exception e) {result.setCode(0);result.setMessage(e.getMessage());result.setFlag(false);
}
return result;

Mapper XML

<!-- 获取分页数据并计算总条数 -->
<select id="getList" parameterType="map" resultType="map">SELECT SQL_CALC_FOUND_ROWS *FROM tableWHERE 查询条件LIMIT 页码, 条数;
</select><!-- 获取总条数 -->
<select id="getCount" resultType="int">SELECT FOUND_ROWS();
</select>

http://www.ppmy.cn/devtools/53594.html

相关文章

easyexcel和poi版本冲突报错深入解析v2

easyexcel报错解决 问题 项目由poi改用easyexcel&#xff0c;报错如下&#xff1a; java.lang.NoSuchMethodError: ‘org.apache.poi.ss.usermodel.CellType org.apache.poi.ss.usermodel.Cell.getCellType()’ 原因 easyexcel中的poi和项目原本的poi版本冲突问题。 由于之前做…

uniapp怎么实现条形码

"uniapp" 指的是 UniApp&#xff0c;一个使用 Vue.js 开发所有前端应用的框架&#xff0c;可以编译到iOS、Android、H5、以及各种小程序等多个平台。 在 UniApp 中实现条形码&#xff0c;你通常会使用第三方库。以下是一个简单的步骤说明如何在 UniApp 中实现条形码…

【C语言】一维数组(详解)

目录 1. 数组的概念 2. 一维数组的创建和初始化 3. 一维数组的使用 4. 一维数组在内存中的存储 5. sizeof 计算数组元素个数 正文开始—— 1. 数组的概念 数组是一组相同类型元素的集合。 数组中存放的是1个或者多个数据&#xff0c;但是数组元素个数不能为0。…

打开nginx连接的php页面报错502

目录 问题描述&#xff1a; 原因&#xff1a; 1. 使用 Unix 域套接字&#xff08;Unix Socket&#xff09; 区别和优势&#xff1a; 2. 使用 TCP/IP 套接字 区别和优势&#xff1a; 如何选择 扩展&#xff1a;Rocky_Linux9.4安装PHP的步骤&#xff1a; 使用Remi存储库…

PXE自动装机

1、概念 涉及到服务端和客户端 配置好一台主机以它为服务端&#xff0c;服务端给客户端提供ip地址、内核文件等&#xff0c;并将这些文件传给客户机&#xff0c;客户机自动安装不需要人为手动操作。 2、组成 PXE&#xff1a;c/s模式&#xff08;客户端和服务端都可以是多台…

React是什么?

theme: condensed-night-purple highlight: atelier-cave-light React是什么&#xff1f; 官方的解释是&#xff1a;A JavaScript library for building user interfaces用于构建用户界面的 JavaScript 库 那为什么要选择用React呢&#xff1f; 原生的HTML、CSS、JavaScrip的…

java技术专家面试指南100问【java学习+面试宝典】(四)

如何避免“伪共享”&#xff1f; 字节填充&#xff08;创建变量时&#xff0c;使用字段对其进行填充&#xff0c;避免多个变量被分派到同一个缓存行里&#xff09;。JDK8提供了一个Contended注解来解决伪共享。 Netty 的应用场景了解么&#xff1f; Netty 主要用来做网络通信…

html中如何写一个提示框,css画一个提示框

在HTML中&#xff0c;提示框通常使用<div>元素来创建&#xff0c;然后使用CSS进行样式化。以下是一个示例&#xff0c;展示如何在HTML中写一个提示框&#xff0c;并使用CSS来设计其外观。 HTML 首先&#xff0c;创建一个HTML文件&#xff0c;其中包含一个提示框的结构&…