Mysql 大分页优化

栏目: 数据库 · Mysql · 发布时间: 6年前

内容简介:看到数据库报警,查看慢 sql 日志看到执行了 90 秒,扫描了 1329172 行。先解决大分页的问题(

看到数据库报警,查看慢 sql 日志看到

select id, content from zixun_article where status = 1 order by id asc limit 1328000, 1000

执行了 90 秒,扫描了 1329172 行。

两个问题

  • 大分页问题
  • 索引问题

先解决大分页的问题( 这个经验是高级数据库专家之前分享的 )修改后

select a2.id, a2.content from (select id from zixun_article where status = 1 order by id asc limit 1309000, 1000) a1, zixun_article a2 where a1.id=a2.id;

我看到 status 上是没有索引的,所以直接改成

select a2.id, a2.content,a2.status from (select id from zixun_article order by id asc limit 1309000, 1000) a1, zixun_article a2 where a1.id=a2.id;

然后再到业务代码里面去根据 status 去做筛选。

总结

这种数据量很大的表,应该是先做一个子查询查出 id(只会在索引里面扫描),然后关联查询,这样扫描的行数是限定的。而不会扫描表前面所有的行。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

《裂变:秒懂人工智能的基础课》

《裂变:秒懂人工智能的基础课》

王天一 / 电子工业出版社·博文视点 / 2018-6-13 / 59.00元

人工智能是指通过普通计算机程序实现的人类智能技术,这一学科不仅具有非凡的科学意义,对人类自身生存方式的影响也在不断加深。本书作为人工智能领域的入门读物,内容围绕人工智能的核心框架展开,具体包括数学基础知识、机器学习算法、人工神经网络原理、深度学习方法与实例、深度学习之外的人工智能和实践应用场景等模块。本书力图为人工智能初学者提供关于这一领域的全面认识,也为进一步的深入研究建立坚实的基础。一起来看看 《《裂变:秒懂人工智能的基础课》》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换