日期:2010-01-22  浏览次数:20504 次

下面就来重点说说这几种分页方式:

一般情况下我们都是通过sql语句来分页,这在无论哪种开发语音都是通用的,

使用sql语句或者存储过程分页的方式最主要的是要在读取数据的时候把sql语句或者存储过程写好,它的原理是只读取当前要显示的几行记录,所以要根据页数和每页显示的数目来写语句,如下:

Select top pageSize * from News where id not in(select top (Page-1)*pageSize id from News)

很显然只要将pageSize和Page作为参数就可以了,然后再前台调用的时候只要指定当前页数和每页显示的数目,就可以实现分页了,为了显示总数目,还可以读取所有数目,需要注意的时候,如果是自定义分页视图,由于.net在回传的时候不保存当前页,所以要使用ViewState来保存页数,每次只读取所需要的几条记录,所以适合做大型网站数量比较大的时候使用

另外一种分页方式就是使用.net提供的PageDataSource类来分页,

PageDataSource是微软提供一个用于分页使用的类,集成了绑定控件的一些方法,在使用的时候,我们只需要从数据库读取我们所要的数据,绑定到PageDataSource即可,然后允许PageDataSource可以分页,指定当前页和每页要显示的数目,这样就可以很好的获得的总的数目,结合控件,ViewState就可以完成自定义分页视图,方法如下:

PagedDataSource pageDataSource = new PagedDataSource();

pageDataSource.DataSource = NewsManager.GetNews();//所有记录

pageDataSource.AllowPaging = true;

pageDataSource.PageSize = 16;

pageDataSource.CurrentPageIndex = Pager– 1;