今天在做数据库练习的时候由于数据有点多,一下全部显示出来不好看,看着比较乱,所以在查了一下怎么让MySQL分页找到了一篇不错的文章,在这里分享给大家。如果有帮到大家麻烦点个赞。谢谢。


方法1: 直接使用数据库提供的SQL语句

—语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N。

—适应场景: 适用于数据量较少的情况(元组百/千级)。

—原因/缺点: 全表扫描,速度会很慢 且 有的数据库结果集返回不稳定(如某次返回1,2,3,另外的一次返回2,1,3)。Limit限制的是从结果集的M位置处取出N条输出,其余抛弃。


方法2: 建立主键或唯一索引, 利用索引(假设每页10条)

—语句样式: MySQL中,可用如下方法:

复制代码 代码如下:
SELECT * FROM 表名称 WHERE id_pk > (pageNum*10) LIMIT M。

—适应场景: 适用于数据量多的情况(元组数上万)。

—原因: 索引扫描,速度会很快。有朋友提出因为数据查询出来并不是按照pk_id排序的,所以会有漏掉数据的情况,只能方法3。


方法3: 基于索引再排序

—语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 WHERE id_pk > (pageNum*10) ORDER BY id_pk ASC LIMIT M。

—适应场景: 适用于数据量多的情况(元组数上万). 最好ORDER BY后的列对象是主键或唯一所以,使得ORDERBY操作能利用索引被消除但结果集是稳定的(稳定的含义,参见方法1)。

—原因: 索引扫描,速度会很快. 但MySQL的排序操作,只有ASC没有DESC(DESC是假的,未来会做真正的DESC,期待)。


方法4: 基于索引使用prepare(第一个问号表示pageNum,第二个?表示每页元组数)

—语句样式: MySQL中,可用如下方法:

复制代码 代码如下:
PREPARE stmt_name FROM SELECT * FROM 表名称 WHERE id_pk > (?* ?) ORDER BY id_pk
ASC LIMIT M。

—适应场景: 大数据量。

—原因: 索引扫描,速度会很快. prepare语句又比一般的查询语句快一点。


方法5:利用MySQL支持ORDER操作可以利用索引快速定位部分元组,避免全表扫描

—比如: 读第1000到1019行元组(pk是主键/唯一键)。

复制代码 代码如下:
—SELECT * FROM your_table WHERE pk>=1000 ORDER BY pk ASC LIMIT 0,20。


方法6: 利用"子查询/连接+索引"快速定位元组的位置,然后再读取元组. 道理同方法5

—如(id是主键/唯一键,蓝色字体时变量):

利用子查询示例:

复制代码 代码如下:
SELECT* FROMyour_table WHEREid <=
(SELECTid FROMyour_table ORDER
BYid descLIMIT (page−1)∗page-1)*page−1)∗pagesize ORDERBYid desc
LIMIT $pagesize

利用连接示例:
复制代码 代码如下:
SELECT* FROMyour_table ASt1
JOIN(SELECTid FROMyour_table ORDERBY
id descLIMIT (page−1)∗page-1)*page−1)∗pagesize ASt2
WHERE
t1.id <= t2.id ORDERBYt1.id descLIMIT $pagesize;


方法7: 存储过程类(最好融合上述方法5/6)

—语句样式: 不再给出

—适应场景: 大数据量. 作者推荐的方法

—原因: 把操作封装在服务器,相对更快一些。


方法8: 反面方法

—网上有人写使用 SQL_CALC_FOUND_ROWS。 没有道理,勿模仿 。

基本上,可以推广到所有数据库,道理是一样的。但方法5未必能推广到其他数据库,推广的前提是,其他数据库支持ORDER BY操作可以利用索引直接完成排序。


文章原址 8种MySQL分页方法总结

8种MySQL分页方法总结相关推荐

  1. Oracle、SQL Server、MySQL分页方法

    测试用例:查询TEST_TABLE表中TEST_COLUMN列的第10-20条数据 1,Oracle分页方法 [sql] view plain copy   SELECT A.* FROM ( SEL ...

  2. mysql分页查询_4种MySQL分页查询优化的方法,你知道几个?

    前言 当需要从数据库查询的表有上万条记录的时候,一次性查询所有结果会变得很慢,特别是随着数据量的增加特别明显,这时需要使用分页查询.对于数据库分页查询,也有很多种方法和优化的点.下面简单说一下我知道的 ...

  3. mysql工具分页原理_高效的mysql分页方法及原理

    首先看一下分页的基本原理: 复制代码 代码如下: mysql> explain SELECT * FROM message ORDER BY id DESC LIMIT 10000, 20G * ...

  4. 事物日志恢复 mysql_一种基于事务日志的Mysql数据恢复方法与流程

    本发明涉及一种mysql数据恢复方法,尤其涉及一种基于事务日志的mysql数据恢复方法. 背景技术: :在对mysql数据库进行日常操作的过程中,总是无法避免会产生各种误删数据,误改数据等操作.这个时 ...

  5. MySQL.分页 慢日志查询

    limit分页 select * from table_name limit 0,5  或者  select * from table_name limit 5 #取前5条数据 select * fr ...

  6. mysql 高效分页查询_PostgreSQL、MySQL高效分页方法探讨

    对于数据库相关的业务,逃不过的数据分页场景,无论是前台分页浏览还是划到页面底部自动加载.对于分页需求,各数据库也提供了成熟的SQL支持,类似于Hibernate等ORM框架也集成了相关的方法.但是基于 ...

  7. php调用mysql库_PHP调用三种数据库的方法(1)

    PHP调用三种数据库的方法(1) 更新时间:2006年10月09日 00:00:00   作者: MySQL是一个小巧灵珑的数据库服务器软件,对于中.小型应用系统是非常理想的.除了支持标准的ANSI ...

  8. java mysql 分页查询_MySQL分页查询方法及优化

    当数据库的数据量很大时,一次性查询结果就会变得很慢,为了提高查询效率,我们可以使用MySQL的分页查询功能.本文就为大家带来MySQL分页查询方法及优化. 推荐阅读: 分页查询方法: 在MySQL中, ...

  9. sql server两种分页方法

    方法一: --分页方法一 select top 10 OrderID,CustomerID, EmployeeID,OrderDate,ShippedDate,ShipName,ShipAddress ...

最新文章

  1. e语言怎么连接mysql_大佬们E语言连接MYSQL输出中文乱码怎么破
  2. JavaWeb:JavaScript
  3. php 登录记住密码,php 记住密码自动登录
  4. “我今年 31 岁,工作 7 年,明年退休...”
  5. 网友反映摩拜单车无法扫码 回应:系技术问题 现已恢复服务
  6. 字符串交错组成--很优美的递归算法
  7. DirectShow之视频渲染
  8. key去掉下划线自动大写首字母工具类
  9. python交通标志识别_利用pytorch实现交通标志识别
  10. awk 分隔符 多个空格_awk多分隔符
  11. 接受数据的php文件源码,PHP文件上传源码分析(RFC1867)
  12. 重磅推出:2019中国开源年度报告
  13. 大语言模型将如何影响软件开发?
  14. 雷军:别轻易尝试,要做好准备再去创业
  15. html5 video标签实现手机端视频播放全屏显示
  16. 用手写板向计算机输入汉字是什么技术,手写板是什么
  17. 古玩文物字画寄售系统源码/拍卖商城系统源码/竞拍系统源码转拍系统
  18. 内存不能为“read”或written的解决
  19. java23种开发模式
  20. 计蒜客 联想专卖店大促销 二分

热门文章

  1. 松下发布自动洗头机器人
  2. leetcode编程练习
  3. tcp报文黏连及解决方法
  4. 在WPS中提取出的照片在哪找_WPS 智能辅助写作平台架构实践分享
  5. 仿QQ空间说说TextView内容显示、收起
  6. 一文梳理支付宝2021年:向商家开放,让私域唱主角
  7. Javascript 深度克隆中的循环引用问题解决和代码优化
  8. 最新导游资格证考试综合模拟题及答案
  9. Android 13 来了,你不能错过的 10+ 新变化~
  10. C语言:strcmp原理