Mysql应用MySQL对limit查询语句的优化方法
《Mysql应用MySQL对limit查询语句的优化方法》要点: 当我们的网站达到一定的规模时,网站的各种优化是必须要进行的.而网站的优化中,针对数据库各种优化是最重点的了.下面作者将要和大家分享一下MySQL数据库中的查询语句有关limit语句的优化.MYSQL必读 大家都知道一般limit是用在分页的程序的分页上的,当你的应用数据量够小的时候,也许你感觉不到limit语句的任何问题,但当查询数据量达到一定程度的时候,limit的性能就会急剧下降.这个是通过大量实例得出来的结论.MYSQL必读 下面通过具体的案例来说明,这里是对同一张表在不同的地方取10条数据: 这条SQL语句多次运行,时间保持在0.0004-0.0005之间. 代码如下: Select * From user Where uid >=( Select uid From user Order By uid limit 10,1 ) limit 10; 这条SQL语句多次运行,时间保持在0.0005-0.0006之间,主要是0.0006. 结论:偏移offset较小的时候,直接使用limit较优.这个显然是子查询的原因. (2)offset大的时候 代码如下: select * from user limit 10000,时间保持在0.0187左右 代码如下: Select * From user Where uid >=( Select uid From user Order By uid limit 10000,时间保持在0.0061左右,只有前者的1/3.可以预计offset越大,后者越优. 经过以上对比,我们得出一个结论是使用limit语句时,当数据量偏移量较小的时候可以直接使用limit,当数据量偏移量较大的时候,我们可以适当的使用子查询来做相关的性能优化.MYSQL必读 (编辑:岳阳站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- php – 使用带有symfony3的postgres数据库
- 使用MySql选择记录范围
- Mysql2 ::错误:此MySQL版本不允许使用命令:LOAD DATA LOC
- Mysql入门SQL中实现SPLIT函数几种方法总结(必看篇)
- 哪个在MySQL where子句中表现更好:YEAR()vs BETWEEN?
- mysql – 将大型MyISAM表转换为InnoDB
- mysql – 使用DECIMAL的原因(31,0)
- Mysql应用mysql 5.7.12 winx64安装配置方法图文教程
- 如何与云关系数据库(在MySQL中)进行闪亮的应用程序对话?
- Mysql学习PHP之Mysql常用SQL语句示例的深入分析