MYSQL limit的优化
来源:互联网 发布:单片机湿度程序 编辑:程序博客网 时间:2024/06/08 20:01
MYSQL的优化是非常重要的。其他最常用也最需要优化的就是limit。mysql的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降。
同样是取10条数据
select * from yanxue8_visit limit 10000,10
和
select * from yanxue8_visit limit 0,10
就不是一个数量级别的。
网上也很多关于limit的五条优化准则,都是翻译自mysql手册,虽然正确但不实用。今天发现一篇文章写了些关于limit优化的,很不错。原文地址:http://www.zhenhua.org/article.asp?id=200
文中不是直接使用limit,而是首先获取到offset的id然后直接使用limit size来获取数据。根据他的数据,明显要好于直接使用limit。这里我具体使用数据分两种情况进行测试。(测试环境win2033+p4双核(3GHZ) +4G内存 mysql 5.0.19)
1、offset比较小的时候。
select * from yanxue8_visit limit 10,10
多次运行,时间保持在0.0004-0.0005之间
Select * From yanxue8_visit Where vid >=(
Select vid From yanxue8_visit Order By vid limit 10,1
) limit 10
多次运行,时间保持在0.0005-0.0006之间,主要是0.0006
结论:偏移offset较小的时候,直接使用limit较优。这个显然是子查询的原因。
2、offset大的时候。
select * from yanxue8_visit limit 10000,10
多次运行,时间保持在0.0187左右
Select * From yanxue8_visit Where vid >=(
Select vid From yanxue8_visit Order By vid limit 10000,1
) limit 10
多次运行,时间保持在0.0061左右,只有前者的1/3。可以预计offset越大,后者越优。
Tags - mysql , limit
- MYSQL limit的优化
- MYSQL limit的优化
- MYSQL limit的优化
- mysql的limit优化
- mysql的limit优化
- mysql的limit优化
- mysql的limit的优化
- mysql的limit的优化
- Mysql中limit的优化
- 优化mysql 的 limit offset
- mysql中limit的优化
- 优化mysql的limit offset
- mysql的limit性能优化
- 关于MySQL的limit优化
- 优化 MySQL 查询的 Limit 参数
- 优化 MySQL 查询的 Limit 参数
- 也谈mysql的limit优化
- Mysql的LIMIT简介 及 优化
- 封装SWT组件的原则
- ORA-01000: maximum open cursors exceeded.
- 老友记台词学习笔记 SE01EP03(二)
- 算术表达式求值@C/C++
- 如何用CSC.exe来编译C#程序!
- MYSQL limit的优化
- 厦门主要IT企业名单(至20071205)
- 使用函数递归实现基于PHP和MySQL的动态树型菜单
- 聊天中提到的几个基础问题
- 用模板生成文件示例
- System.Web.UI.Page
- Sys.WebForms.PageRequestManagerServerErrorException: An unknown error occurred while processing the request on the server. The s
- Session永久有效的实现方法
- 18位身份证标准