Mysql 分页技术总结

 

Mysql Pagination

 

1. 使用cursor方式进行数据分页。

http://timyang.net/web/pagination/

对于大结果集的数据,使用cursor方式的目的主要是为了极大地提高性能。还是拿MySQL为例说明,比如翻页到100,000条时,不用cursor,对应的SQL为

select * from msgs limit 100000, 100

需要查询100000+100条数据,然后丢弃100000条,保留100条。

在一个百万记录的表上,第一次执行这条SQL需要5秒以上。
假定我们使用表的主键的值作为cursor_id, 使用cursor分页方式对应的SQL可以优化为

select * from msgs where id > cursor_id limit 100;

同样的表中,通常只需要100ms以下, 效率会提高几十倍。

 

不可以使用limit M, N

但可以使用limit N,而使用而外的clue(线索、条件),来实现从M开始的功能。

 

2.几位yahoo工程师的mysql分页技术的总结:很不错

http://www.percona.com/ppc2009/PPC2009_mysql_pagination.pdf

 

http://www.fuchaoqun.com/2009/04/efficient-pagination-using-mysql/

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值