海量数据高性能分页

海量数据高性能分页数据库

 

条件:主键必须为自增数形式……大部分数据库都知足此形式……缓存

若是A表主键不是自增长形式,能够新建一个C表,将主键设为自增,把内容设为A表主键……这样就至关于作了个适配接口……HH..查询的时候先查C表,获得分页的A表主键,而后拿这些主键再查A表,性能就大大提高了。ide

 

通常的分页都须要两次TOP语句,这样性能有问题,面对海量数据……访问数据库读取Count(*)条数,这个总条数能够缓存起来,没必要每次都查库……性能

 

不走1:将表主键所有连续起来。若是主键不连续,从新创建此列,设下索引连续起来。spa

不走2:由于主键都是数字ID自增。因此分页只须要计算ID值就能够了。索引

不走3:好比读取分页5的内容,pagesize10……则只用如下SQL语句就能够了。接口

 

start =(5-1)*10=40;it

 end=5*10=50;table

Select  * from table where id>40 and id<50class

 

注意:若是表中由于CRUD而不连续,若是不太严重,也能够不用管,就是有时候查的时候可能每页记录数曾参不齐……可是并不影响体验……若是ID不少都不连续了,最好是从新排一下ID.

相关文章
相关标签/搜索