优化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中limit可以实现快速分页,但是如果数据到了几百万时我们的limit必须优化才能有效的合理的实现分页...
    bycall阅读 4,060评论 0 5
  • 如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB。对数据的各种操作也是愈加的困难,传统的关系性...
    CaesarXia阅读 11,882评论 1 30
  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,060评论 0 19
  • 系统层面(基本不用动,看了下,买的云服务器基本都已经优化过了) 内核相关参数(/etc/sysctl.conf) ...
    神奇大叶子阅读 2,057评论 0 4
  • 国内下雪了,据说各地都很冷,北方的小伙伴们靠着暖气吃冰棍,南方的小伙伴们,坐在床上打哆嗦。 澳洲的小伙伴们与阴阳天...
    DrPepper阅读 422评论 0 0