Mysql优化-大数据量下的分页策略
技术百科
黄舟
发布时间:2017-03-02
浏览: 次 一。前言
通常,我们分页时怎么实现呢?
SELECT * FROM table ORDER BY id LIMIT 1000, 10;
但是,数据量猛增以后呢?
SELECT * FROM table ORDER BY id LIMIT 1000000, 10;
如上第二条查询时很慢的,直接拖死。
最关键的原因mysql查询机制的问题:
不是先跳过,后查询;
而是先查询,后跳过。(解释如下)
什么意思?比如limit 100000,10,在找到需要的那10条时,先会轮询经过前10W条数据,先回行查询出前100000条的字段数据,然后发现没用舍弃掉,直到最后找到需要的10条。
二。分析
limit offset,N, 当offset非常大时,效率极低,
原因是mysql并不是跳过offset行,然后单取N行,
而是取offset+N行,返回放弃前offset行,返回N行【同前边说的先查询,后跳过】.
效率较低,当offset越大时,效率越低
三。3条优化建议
1:从业务上去解决
办法:不允许翻过100页
以百度为例,一般
翻页到70页左右.
2:不用offset,用条件查询.
例:
mysql> select id, from lx_com limit 5000000,10; +---------+--------------------------------------------+ | id | name | +---------+--------------------------------------------+ | 5554609 |温泉县人民政府供暖中心 | .................. | 5554618 |温泉县邮政鸿盛公司 | +---------+--------------------------------------------+ 10 rows in set (5.33 sec) mysql> select id,name from lx_com where id>5000000 limit 10; +---------+--------------------------------------------------------+ | id | name | +---------+--------------------------------------------------------+ | 5000001 |南宁市嘉氏百货有限责任公司 | ................. | 5000002 |南宁市友达电线电缆有限公司 | +---------+--------------------------------------------------------+ 10 rows in set (0.00 sec)
现象:从5.3秒到不到100毫秒,查询速度大大加快;但是数据结果却不一样
优点:利用where条件来避免掉先查询后跳过的问题,而是条件缩小范围,从而直接跳过。
存在问题: 有时有会发现用此方法与limitM,N,两次的结果不一致[如上边实例所展示]
原因:数据被物理删除过,有空洞.
解决:数据不进行物理删除(可以逻辑删除).
最终在页面上显示数据时,逻辑删除的条目不显示即可.
(一般来说,大网站的数据都是不物理删除的,只做逻辑删除 ,比如 is_delete=1)
3:延迟索引.
非要物理删除,还要用offset精确查询,还不限制用户分页,怎么办?
优化思路:
利用索引覆盖,快速查询出满足条件的主键id;然后凭借主键id作为where条件,达到快速查询。
(速度快在哪里?利用索引覆盖不需要回行就可以快速查询出满足条件的id,时间节约在这里了)
我们现在必须要查,则只查索引,不查数据,得到id.再用id去查具体条目. 这种技巧就是延迟索引.
慢原因:
查询100W条数据的id,name,m每次查询回行抛弃,跨过100W后取到真正要的数据。【就是我们刚刚说的,先查询,后跳过】
优化后快原理:
a.利用索引覆盖先查询出主键id,在索引上就拿到信息了,避免回行
b.找到主键后,根据已知的目标主键在查询,避免跨大数据行去寻找,而是直接定位哪几条数据直接查询。
本方法即延迟索引查询。
mysql> select id,name from lx_com inner join (select id from lx_com limit 5000000,10) as tmp using(id); +---------+-----------------------------------------------+ | id | name | +---------+-----------------------------------------------+ | 5050425 | 陇县河北乡大谈湾小学 | ........ | 5050434 | 陇县堎底下镇水管站 | +---------+-----------------------------------------------+ 10 rows in set (1.35 sec)
四。总结:
从方案上来说,肯定是方法一优先,从业务上去满足是否要翻那么多页。
如果业务要求,则用id>n limit m的方式来代替limit n,m,但缺点是不能有物理删除
如果非有物理删除有空缺不能用方法二,则用延迟索引法,本质是利用索引覆盖先快速取出索引值,根据锁定的目标的索引值。一次性去回行取值,效果很明显。
以上就是Mysql优化-大数据量下的分页策略的内容,更多相关内容请关注PHP中文网(www.)!
# 都是
# 相关内容
# 分页
# 跳过
# 在这
# 南宁市
# mysql
# 主键
# 则用
# 陇县
# 温泉县
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Windows的便笺功能如何使用?(桌面备忘技巧)
- 如何诊断并终止卡死的 multiprocessin
- Win11怎样安装剪映专业版_Win11安装剪映教
- php怎么捕获异常_trycatch结构处理运行时
- Windows10如何查看蓝屏日志_Win10使用
- Win11如何关闭游戏模式 Win11禁用Xbox
- c++怎么操作redis数据库_c++ hired
- Golang如何避免指针逃逸_Golang逃逸分析
- Windows 11怎么设置默认解压软件_Wind
- php怎么下载安装后测试是否成功_简单脚本验证方法
- Win11如何设置文件权限 Win11 NTFS文
- Windows如何使用注册表查找和删除项?(reg
- php删除数据怎么加限制_带where条件删除避免
- Win11输入法切换快捷键怎么改_Windows
- 使用类变量定义字符串常量时的类型安全最佳实践
- MAC如何快速搜索大文件_MAC磁盘空间分析与冗余
- PHP主流架构如何处理会话管理_Session与C
- Python 模块的 __name__ 属性如何由
- mac怎么右键_MAC鼠标右键设置与触控板手势技巧
- php怎么下载安装并配置环境变量_命令行调用PHP
- Win11怎么关闭应用权限_Windows11相机
- Drupal 中 HTML 链接被重复转义导致渲染
- LINUX如何查看文件类型_Linux中file命
- Linux怎么禁止Root用户远程登录_Linux
- Windows音频驱动无声音原因解析_声卡驱动错误
- c# Task.Yield 的作用是什么 它和Ta
- Win11怎样安装网易云音乐_Win11安装网易云
- Win11怎么关闭透明效果_Windows11辅助
- Python字符串操作教程_切片拼接与格式化详解
- Win11文件夹预览图不显示怎么办_Win11缩略
- PhpStorm怎么调试PHP代码_PhpStor
- c++的mutex和lock_guard如何使用
- Win11怎样激活系统密钥_Win11系统密钥激活
- 一文详解网站被黑客入侵挂马解决办法
- Python多进程教程_multiprocessi
- Python lxml的etree和Element
- Python安全爬虫设计_IP代理池与验证码识别策
- MAC怎么使用表情符号面板_MAC Emoji快捷
- 如何使用Golang安装API文档生成工具_快速生
- Windows10系统更新错误0x80070002
- Windows怎样关闭Edge新标签页广告_Win
- 新手学PHP架构总混淆概念咋办_重点梳理【教程】
- 如何更改Windows资源管理器的默认启动位置?(
- c++如何利用doxygen生成开发文档_c++
- Go 中 defer 语句在 goroutine
- 如何关闭Win10自动更新更新_Win10系统自动
- php能跑在stm32上吗_php在stm32微控
- ACF 教程:正确更新嵌套在多层 Group 字段
- Win11怎么设置触控板手势_Windows11三
- Python文件操作优化_大文件与流处理解析【教程

QQ客服