8种MySQL分页方法总结
今天在做数据库练习的时候由于数据有点多,一下全部显示出来不好看,看着比较乱,所以在查了一下怎么让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分页方法总结相关推荐
- Oracle、SQL Server、MySQL分页方法
测试用例:查询TEST_TABLE表中TEST_COLUMN列的第10-20条数据 1,Oracle分页方法 [sql] view plain copy SELECT A.* FROM ( SEL ...
- mysql分页查询_4种MySQL分页查询优化的方法,你知道几个?
前言 当需要从数据库查询的表有上万条记录的时候,一次性查询所有结果会变得很慢,特别是随着数据量的增加特别明显,这时需要使用分页查询.对于数据库分页查询,也有很多种方法和优化的点.下面简单说一下我知道的 ...
- mysql工具分页原理_高效的mysql分页方法及原理
首先看一下分页的基本原理: 复制代码 代码如下: mysql> explain SELECT * FROM message ORDER BY id DESC LIMIT 10000, 20G * ...
- 事物日志恢复 mysql_一种基于事务日志的Mysql数据恢复方法与流程
本发明涉及一种mysql数据恢复方法,尤其涉及一种基于事务日志的mysql数据恢复方法. 背景技术: :在对mysql数据库进行日常操作的过程中,总是无法避免会产生各种误删数据,误改数据等操作.这个时 ...
- MySQL.分页 慢日志查询
limit分页 select * from table_name limit 0,5 或者 select * from table_name limit 5 #取前5条数据 select * fr ...
- mysql 高效分页查询_PostgreSQL、MySQL高效分页方法探讨
对于数据库相关的业务,逃不过的数据分页场景,无论是前台分页浏览还是划到页面底部自动加载.对于分页需求,各数据库也提供了成熟的SQL支持,类似于Hibernate等ORM框架也集成了相关的方法.但是基于 ...
- php调用mysql库_PHP调用三种数据库的方法(1)
PHP调用三种数据库的方法(1) 更新时间:2006年10月09日 00:00:00 作者: MySQL是一个小巧灵珑的数据库服务器软件,对于中.小型应用系统是非常理想的.除了支持标准的ANSI ...
- java mysql 分页查询_MySQL分页查询方法及优化
当数据库的数据量很大时,一次性查询结果就会变得很慢,为了提高查询效率,我们可以使用MySQL的分页查询功能.本文就为大家带来MySQL分页查询方法及优化. 推荐阅读: 分页查询方法: 在MySQL中, ...
- sql server两种分页方法
方法一: --分页方法一 select top 10 OrderID,CustomerID, EmployeeID,OrderDate,ShippedDate,ShipName,ShipAddress ...
最新文章
- e语言怎么连接mysql_大佬们E语言连接MYSQL输出中文乱码怎么破
- JavaWeb:JavaScript
- php 登录记住密码,php 记住密码自动登录
- “我今年 31 岁,工作 7 年,明年退休...”
- 网友反映摩拜单车无法扫码 回应:系技术问题 现已恢复服务
- 字符串交错组成--很优美的递归算法
- DirectShow之视频渲染
- key去掉下划线自动大写首字母工具类
- python交通标志识别_利用pytorch实现交通标志识别
- awk 分隔符 多个空格_awk多分隔符
- 接受数据的php文件源码,PHP文件上传源码分析(RFC1867)
- 重磅推出:2019中国开源年度报告
- 大语言模型将如何影响软件开发?
- 雷军:别轻易尝试,要做好准备再去创业
- html5 video标签实现手机端视频播放全屏显示
- 用手写板向计算机输入汉字是什么技术,手写板是什么
- 古玩文物字画寄售系统源码/拍卖商城系统源码/竞拍系统源码转拍系统
- 内存不能为“read”或written的解决
- java23种开发模式
- 计蒜客 联想专卖店大促销 二分