php MySQL与分页效率

 更新时间:2008年06月04日 19:57:59   作者:  
作者:老王 如果和MSSQL的TOP语法相比,那么MySQL的LIMIT语法要显得优雅了许多。使用它来分页是再自然不过的事情了。
 
最基本的分页方式:
SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT ...
在中小数据量的情况下,这样的SQL足够用了,唯一需要注意的问题就是确保使用了索引:
举例来说,如果实际SQL类似下面语句,那么在category_id, id两列上建立复合索引比较好:
SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 50, 10

子查询的分页方式:

随着数据量的增加,页数会越来越多,查看后几页的SQL就可能类似:

SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 10

一言以蔽之,就是越往后分页,LIMIT语句的偏移量就会越大,速度也会明显变慢。

此时,我们可以通过子查询的方式来提高分页效率,大致如下:

SELECT * FROM articles WHERE category_id = 123 AND id >= (
    SELECT id FROM articles ORDER BY id LIMIT 10000, 1
) LIMIT 10

----------------------------------------

实际可以利用类似策略模式的方式去处理分页,比如判断如果是一百页以内,就使用最基本的分页方式,大于一百页,则使用子查询的分页方式。

相关文章

  • PHP 设置MySQL连接字符集的方法

    PHP 设置MySQL连接字符集的方法

    我之前总是使用 mysql_query("SET NAMES 'utf8'"); 来设置 MySQL 的默认连接字符集;但是今天发现了一个 PHP 推荐的代替这个方法的设置 MySQL 连接字符集的函数
    2011-01-01
  • PHP iconv 函数转gb2312的bug解决方法

    PHP iconv 函数转gb2312的bug解决方法

    之前写过一篇解决xajax库中文乱码的问题,说到可以用 iconv( "UTF-8", "gb2312" , $FormValues['a']) 来转换,最近发现更好的写法应该是。
    2009-10-10
  • PHP sleep()函数, usleep()函数

    PHP sleep()函数, usleep()函数

    这篇文章主要介绍了PHP sleep()函数, usleep()函数,需要的朋友可以参考下
    2016-08-08
  • PHP中实现中文字符进制转换原理分析

    PHP中实现中文字符进制转换原理分析

    中文字符编码研究系列第四期,PHP实现中文字符进制转换原理分析,主要讨论中文汉字转换为十进制和十六进制的方法,并掌握转换原理应用于实际开发。本文以GBK编码字符为例,讨论GBK编码的字符转换原理
    2011-12-12
  • PHP实现的mysql主从数据库状态检测功能示例

    PHP实现的mysql主从数据库状态检测功能示例

    这篇文章主要介绍了PHP实现的mysql主从数据库状态检测功能,结合具体实例形式分析了php检测多个mysql主从数据库连接状态的相关实现技巧,需要的朋友可以参考下
    2017-07-07
  • PHP编程获取各个时间段具体时间的方法

    PHP编程获取各个时间段具体时间的方法

    这篇文章主要介绍了PHP编程获取各个时间段具体时间的方法,结合实例形式分析了基于date与strtotime函数进行日期时间运算的相关操作技巧,需要的朋友可以参考下
    2017-05-05
  • PHP中返回引用类型的方法

    PHP中返回引用类型的方法

    这篇文章主要介绍了PHP中返回引用类型的方法,这是个比较容易混淆的概念,如果不是出于某些特殊的原因,建议还是不要使用,需要的朋友可以参考下
    2015-04-04
  • 通过php修改xml文档内容的方法

    通过php修改xml文档内容的方法

    这篇文章主要介绍了通过php修改xml文档内容的方法,涉及php针对XML节点的赋值与保存操作,需要的朋友可以参考下
    2015-01-01
  • PHP MYSQL实现登陆和模糊查询两大功能

    PHP MYSQL实现登陆和模糊查询两大功能

    这篇文章主要介绍了PHP MYSQL实现登陆和模糊查询两大功能,分别介绍了PHP MYSQL实现登陆和模糊查询功能的方法,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • php array_map()函数实例用法

    php array_map()函数实例用法

    在本篇文章里小编给大家分享了一篇关于php array_map()函数实例用法,有兴趣的朋友们可以学习下。
    2021-03-03

最新评论