优化MySQL分页

之前写的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时

参考:
0.MySQL数据库开发的三十六条军规石展完整.pdf
1.**mysql LIMIT 子句用法及原理 **

你可能感兴趣的:(优化MySQL分页)