之前写的SQL查询语句根本没有考虑到性能方面的问题,一是自己没有经验,二是因为网站规模小数据量不大,自然感受不到查询带来的性能问题。
最近由于数据量开始真大,在大后台一个产品列表的页面卡住了好久。最近也在阅读《高性能MYSQL》,就觉得将查询的语句优化下。废话结束。
-
传统分页:
- SELECT * FROM table LIMIT 100000,10
-
LIMIT的原理:
- LIMIT 偏移量,条数
- 当偏移量越大,速度越慢。
-
推荐方法:
- SELECT * FROM table WHERE id>=100000 LIMIT 11 #10+1 (每页10条);
- SELECT * FROM table INNER JOIN (SELECT id FROM table LIMIT 100000,10) AS t USING(id);
- SELECT * FROM table WHERE id>=(SELECT id FROM table LIMIT 100000,1) LIMIT 10;
- SELECT id FROM table LIMIT 100000,10;
SELECT * FROM table WHERE id IN(100,101...,110);
-
其他:
- 尽量不用SELECT * ,只取需要数据列
- 更安全的设计:减少表变化带来的影响
- 为使用covering index提供可能性
- Select/JOIN减少硬盘临时表生成,特别是有TEXT/BLOB时
- 尽量不用SELECT * ,只取需要数据列
参考:
0.MySQL数据库开发的三十六条军规石展完整.pdf
1.**mysql LIMIT 子句用法及原理 **