SQL查询一页数据过多太慢

一页取5000~10000条数据 查询很慢

1)加索引

2)设置fetchSize

@Select("<script> SELECT * from A \n" +

"</script>")

@Options(fetchSize = 3000, resultSetType = ResultSetType.FORWARD_ONLY)

IPage<Object> selectPage(IPage pageInfo,@Param("idList") List<Long> idList);

让我解释一下这些选项的含义:

  1. fetchSize = 1000: 这个选项指定了在从数据库中检索数据时一次性取回的行数。在这种情况下,设置为 1000,意味着每次从数据库中取回的数据行数为 1000。通过设置合适的 fetchSize,可以在一定程度上优化数据库的性能和内存使用情况。

  2. resultSetType = ResultSetType.FORWARD_ONLY: 这个选项指定了结果集的类型。FORWARD_ONLY 表示结果集只能向前遍历,不能向后滚动。这种类型的结果集对于只需要一次性遍历结果集的情况来说是最有效的,因为它不需要额外的资源来支持向后滚动。

  3. resultSetConcurrency = ResultSetConcurrency.READ_ONLY: 这个选项指定了结果集的并发性。READ_ONLY 表示结果集是只读的,不能用于更新数据库。这种设置适用于只需要查询结果而不需要更新数据的情况。

相关推荐
ZeroToOneDev1 小时前
Java(泛型和JUnit)
java·开发语言·笔记
迪尔~2 小时前
Apache POI中通过WorkBook写入图片后出现导出PDF文件时在不同页重复写入该图片问题,如何在通过sheet获取绘图对象清除该图片
java·pdf·excel
现在,此刻3 小时前
leetcode 11. 盛最多水的容器 -java
java·算法·leetcode
全栈工程师修炼指南3 小时前
DBA | SQL 结构化查询语言介绍与学习环境准备
数据库·sql·学习·dba
DKPT3 小时前
Java设计模式之开闭原则介绍与说明
java·设计模式·开闭原则
hyy27952276844 小时前
企业级WEB应用服务器TOMCAT
java·前端·tomcat
布朗克1684 小时前
Spring Boot项目通过Feign调用三方接口的详细教程
java·spring boot·feign
Arva .4 小时前
Spring基于XML的自动装配
xml·java·spring
RationalDysaniaer4 小时前
MySQL时间类型
数据库·mysql
代码的余温5 小时前
MySQL三大存储引擎对比:InnoDB vs MyISAM vs MEMORY
数据库·mysql