让GridView在大数据集时高效的分页
让GridView在大数据集时高效的分页在ASP.NET 1.1下有一个很好用的数据列表显示控件DataGrid,他有一个专门的设置数据记录数的属性"VirtualItemCount",这样可以很好的解决大数据集的分页问题,即每次读取一页的数据,但还是把数据集总数值赋给这个虚拟记录数属性,也就避免了每次都要读取所有数据 (当然你也可以自定义分页方式,也有很多现成的分页控件,这就不是本文讨论的范围了, 我比较懒,觉得GridView自身的分页功能已经足够用了,呵呵). 到了ASP.NET 2.0,有了更强大的数据显示控件GridView, 但有一个遗憾,它没有了"VirtualItemCount"这个属性, PageCount属性也是只读的,如果你想用它本身的分页功能,只能把所有数据作为它的数据源, 当这个数据集很大时,性能或许会成为一个问题, 或者这样让追求效率的你觉得有些不爽,怎么办?
有一个变通的方法可以解决这个问题:ObjectDataSource.
1. 先需要一个配合ObjectDataSource使用的数据分页设配器:
/// <summary>
/// 分页适配器。
/// </summary>
internal class GridViewPagingAdapter
{
private object m_dataList;
private int m_virtualItemCount;
// 构造一个适配器。
public GridViewPagingAdapter(object list, int rowCount)
{
m_dataList = list;
m_virtualItemCount =
/// 分页适配器。
/// </summary>
internal class GridViewPagingAdapter
{
private object m_dataList;
private int m_virtualItemCount;
// 构造一个适配器。
public GridViewPagingAdapter(object list, int rowCount)
{
m_dataList = list;
m_virtualItemCount =