让GridView在大数据集时高效的分页
让GridView在大数据集时高效的分页在ASP.NET 1.1下有一个很好用的数据列表显示控件DataGrid,他有一个专门的设置数据记录数的属性"VirtualItemCount",这样可以很好的解决大数据集的分页问题,即每次读取一页的数据,但还是把数据集总数值赋给这个虚拟记录数属性,也就避免了每次都要读取所有数据 (当然你也可以自定义分页方式,也有很多现成的分页控件,这就不是本文讨论的范围了, 我比较懒,觉得GridView自身的分页功能已经足够用了,呵呵). 到了ASP.NET 2.0,有了更强大的数据显示控件GridView, 但有一个遗憾,它没有了"VirtualItemCount"这个属性, PageCount属性也是只读的,如果你想用它本身的分页功能,只能把所有数据作为它的数据源, 当这个数据集很大时,性能或许会成为一个问题, 或者这样让追求效率的你觉得有些不爽,怎么办?
有一个变通的方法可以解决这个问题:ObjectDataSource.
1. 先需要一个配合ObjectDataSource使用的数据分页设配器:
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0196c3df5ea9e936f21e9932cca91014.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)