MYSQL分页limit速度太慢
来源:互联网 发布:破解无线网络密码软件 编辑:程序博客网 时间:2024/04/30 07:06
最近一个网站的服务器评论被人刷死,导致mysql数据库异常发生too many open connections
引发的SQL语句
SELECT a.uid, a.veil, a.content, a.datetimes, a.audit, b.user_name, b.uc_id
FROM news_talkabout a
LEFT JOIN users_info b ON a.uid = b.id
WHERE infoid =11087
ORDER BY a.id DESC
LIMIT 451350 , 30
丢在phpmyadmin里执行一下,是很慢。
让人思考是什么因素
SELECT a.uid, a.veil, a.content, a.datetimes, a.audit, b.user_name, b.uc_id
FROM news_talkabout a
LEFT JOIN users_info b ON a.uid = b.id
WHERE infoid =11087
ORDER BY a.id DESC
LIMIT 0 , 30
第一页会很快
PERCONA PERFORMANCE CONFERENCE 2009上,来自雅虎的几位工程师带来了一篇”EfficientPagination Using MySQL“的报告
limit10000,20的意思扫描满足条件的10020行,扔掉前面的10000行,返回最后的20行,问题就在这里。
LIMIT 451350 , 30 扫描了45万多行,怪不得慢的数据库都堵死了。
但是
limit 30 这样的语句仅仅扫描30行。
那么如果我们之前记录了最大ID,就可以在这里做文章
举个例子
日常分页SQL语句
select id,name,content from users order by id asc limit 100000,20
扫描100020行
如果记录了上次的最大ID
select id,name,content from users where id>100073 order by id asc limit 20
扫描20行。
首发于http://java-er.com - http://java-er.com/blog/mysql-limit/
引发的SQL语句
SELECT a.uid, a.veil, a.content, a.datetimes, a.audit, b.user_name, b.uc_id
FROM news_talkabout a
LEFT JOIN users_info b ON a.uid = b.id
WHERE infoid =11087
ORDER BY a.id DESC
LIMIT 451350 , 30
丢在phpmyadmin里执行一下,是很慢。
让人思考是什么因素
SELECT a.uid, a.veil, a.content, a.datetimes, a.audit, b.user_name, b.uc_id
FROM news_talkabout a
LEFT JOIN users_info b ON a.uid = b.id
WHERE infoid =11087
ORDER BY a.id DESC
LIMIT 0 , 30
第一页会很快
PERCONA PERFORMANCE CONFERENCE 2009上,来自雅虎的几位工程师带来了一篇”EfficientPagination Using MySQL“的报告
limit10000,20的意思扫描满足条件的10020行,扔掉前面的10000行,返回最后的20行,问题就在这里。
LIMIT 451350 , 30 扫描了45万多行,怪不得慢的数据库都堵死了。
但是
limit 30 这样的语句仅仅扫描30行。
那么如果我们之前记录了最大ID,就可以在这里做文章
举个例子
日常分页SQL语句
select id,name,content from users order by id asc limit 100000,20
扫描100020行
如果记录了上次的最大ID
select id,name,content from users where id>100073 order by id asc limit 20
扫描20行。
首发于http://java-er.com - http://java-er.com/blog/mysql-limit/
- MYSQL分页limit速度太慢
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢优化方法
- MYSQL分页limit速度太慢的优化方法
- 速度太慢
- 如何查看mysql数据库中哪条SQL访问速度太慢
- conda下载速度太慢
- ubuntu 下载速度太慢
- asp+mysql limit分页
- mysql limit 分页
- mysql分页limit优化
- mysql limit实现"分页"
- MySQL 优化Limit分页
- mysql limit 分页
- hdu 1422 最大子序列和问题的变形,最长非负子序列
- xml的应用
- 魔兽哈希算法封装和测试
- Django框架(一): 安装部署
- 技术人员创业后就不再适合继续编码了?
- MYSQL分页limit速度太慢
- DB2存储过程总结
- Captureing ‘self’ strongly in this block is likely to lead to a retain cycle Block的Retain Cycle的解决方法
- 给自卑的自己一点建议
- 关于运算符重载(泪奔)
- Android的USB打印机部署
- LFS
- oracle 函数
- 触须测试程序