分页技术简介

分页,是一种将所有数据分段展示给用户的技术.用户每次看到的不是全部数据,而是其中的一部分。如果在其中没有找到自习自己想要的内容,用户可以通过制定页码或是翻页的方式转换可见内容,直到找到自己想要的内容为止.其实这和我们阅读书籍很类似,我们不能把整本书的全部内容写在一页纸上。

为什么要分页?

1、加载少量数据,减少客户的和服务器数据交互,降低服务器压力。
2、增强用户体验,每次加载数据量少,加载速度自然就快,用户体验就好。

常见分页样式:

1、 传统分页(分页工具栏),如百度的分页:

2、 自动加载:如QQ空间下拉自动加载数据

  • 传统分页与下拉式分页对比

传统分页可以明确数据信息,数量等;
下拉式无法明确数据量等信息,分页后之前从信息还在页面上。

常见分页实现方式

  • Java程序分页的实现主要是用List 接口中的subList(int startIndex,int endIndex)方法,这种方式也称为程序内存分页。
  • 使用数据库的SQL语句实现数据分页。适用于数据量较大,访问频度较低的操作。如果数据量大,访问频度又高,可以参考大数据分页。

关于内存分页
当数据量较小时推荐使用。使用subList进行分页时,如果数据量比较大是一个非常耗费系统资源的方案。
目前web项目有许多分布式系统,可能有多个系统访问同一个数据库,那么对数据库的开销就比较大了,这时可以考虑对内存分页进行优化,例如利用程序缓存处理机制等。
其实真正的内存分页不是那么简单的事情,要实现一个完整的通用的机制,不是一两个小时就能搞定的。首先有一个数据记录的服务器缓存问题,然后才是数据记录分页问题,这个相对好解决一点,但第一个问题就不太好组织。因为缓存问题涉及到数据的缓存位置,缓存时间,删除时间和利于查询的数据组织问题。

数据库分页:
数据库分页的原理比较明确了,根据需要取结果集中的一部分就是了,没什么好说的。其实这样有时候数据缓存在数据库系统内,可能比内存分页要智能一点。

SQL分页
使用SQL语句实现分页
使用数据库自带的分页语法,获取分页数据,如MySQL的limit关键字,oracle的rownum关键字等

以下是常见的分页SQL语句
1. MySQL分页查询语句:
Select * from t_table limit 1,10;

  1. PostgreSQL分页查询语句
1.  Select * from t_table limit 10 offset 0;
  1. Oracle分页查询SQL:
1.  Select * from ( 
 Select t.*,rownum rn from t_table t where rownum <=10 
 ) where rn >=1;
  1. 使用hibernate框架进行分页: 创建query或者Criteria对象,查询时,设置firstResult和maxResult属性 eg:
1.  String hql = “from student_table”; 
 Query q = session.createQuery(hql); 
 q.setFirstResult(0); 
 q.setMaxResult(10); 
 List l = q.list();
  1. Mybatis分页
    由于mybatis的SQL语句一般都是通过配置文件手工写的,可以直接参考SQL分页。