利用SqlDataAdapter进行分页

利用SqlDataAdapter进行记录分页

说到分页,很多地方都会用到,不管是windows程序还是web程序,为什么要进行分页?很简单,如果BlueIdea BBS帖子列表不分页的话,几十万条记录,可想而知.......

分页有几种方法,可以用存储过程进行分页,将要显示的记录写入一个临时表中,再从临时表中取出这些记录,取出的记录呢,也就是当前页的记录了。
我这里谈到的,是利用SqlDataAdapter Fill方法的重载,进行分页

public int Fill (
    DataSet dataSet,
    int startRecord,
    int maxRecords,
    string srcTable
)

参数:

dataSet
要用记录和架构(如果必要)填充的 DataSet。

startRecord
从其开始的从零开始的记录号。

maxRecords
要检索的最大记录数。

srcTable
用于表映射的源表的名称。

返回值
已在 DataSet 中成功添加或刷新的行数。这不包括受不返回行的语句影响的行。

示例方法:

DataTable tbl = SqlDataAdapter.Fill(objDst,1,10,"temp")

言归正传,在这个设计过程中,我们需要哪些参数呢?

1、_pagesize----int型,每页要显示的记录数

2、_pagecount----总记录数,这是需要算出来的

_pagesize可以在web.config中设定,至于_pagecount嘛,得首先知道总的记录数,所以,我们得先弄出记录数出来,大家可以用一条sql语句查询而得到,这里就不多说了。假定已得知记录数,现在计算总页数

_pagecount = (_recordCount % _pagesize==0) ? (_recordCount / _pagesize) : (_recordCount / _pagesize + 1);

这里用总记录数去除以每页显示的记录数,如果能整除,说明直接用记录数除以页记录数就能得到总页数,否则,就用记录数除页记录数再加上1就可得到总页数了
是不是具备这些就够了呢?
当然不够
想想,Fill方法时的第二个参数startRecord怎么赋值呢?如果是第1页的话很简单,直接传1,因为我们从第1条开始取嘛,如果是第二页呢?怎么办?
假定,我们每页显示10条,当前是第2页,那么应该从多少条开始取??大家应该想到了,应该从11条开始,也就是取11-20条,那这里的11怎么得到?
算法:
(_page-1) * _pagesize + 1
(2-1) * 10 + 1 = 11
其中_page是当前页,但这个数必须大于1
OK,有了这些基础,再来分页就简单了

.....
int _page;
int _pagesize = 10;
int _pagecount;
int _recordcount;
System.Text.StringBuilder sbPager = new System.Text.StringBuilder();  //用来显示分页
//在.aspx页中调用,用以显示分页代码
public string getPager()
{
  return sbPager.ToString();
}
//计算出记录数
_recordcount = 134;
//判断当前页数
private void Page_Load(object sender, System.EventArgs e)
  {
   if(Request.QueryString["page"]==null)
   {
    _page = 1;
   }
   else
   {
    _page = Int16.Parse(Request.QueryString["page"]);
            }
 ...............
  }
//开始填充数据
private void FillList()
  {
   _recordcount= BLL.MessageBLL.getListCount("");    //取得总记录数
   _pagecount = (_recordcount % _pagesize==0)?(_recordcount/_pagesize):(_recordcount/_pagesize+1);    //得到总页数
   int _minPage=1;  
   if(_page!=1)
   {
    _minPage = (_page-1)*_pagesize + 1;
   }
   this.repMsgList.DataSource = BLL.MessageBLL.GetList("",_minPage,_pagesize);
   this.repMsgList.DataBind();
   #region 打印页数
   
    for (int i = 1; i <= _pagecount; i++)
    {
     if (i == _page)
      //如果是当前页,不显示链接
      sbPager.Append("<span >" + i.ToString() + "</span>&nbsp;");
     else
     {
       sbPager.Append("<a href=?page="+i+">" + i + "</a>&nbsp;");
     }
     
    }
   sbPager.Append(_recordcount + " Records");
   #endregion
  }

在前台中
分页:<%=getPager()%>调用就OK了
这样,初级的分页就完成了
但这样写代码很烦琐,看以后能不能写成一个自定义控件.

时间: 2024-11-13 11:43:36

利用SqlDataAdapter进行分页的相关文章

[DB][MyBatis]利用mybatis-paginator实现分页(目前看到MyBatis下最好的分页实现)

利用mybatis-paginator实现分页 1.mybatis-paginator简介 mybatis-paginator是gethub上的一个开源项目.用于java后台获取分页数据.该开源项目还提供一个列表组件(mmgrid)用于前端展示. 该开源项目地址:https://github.com/miemiedev 2.该开源项目的使用说明: Maven中加入依赖: <dependencies> ... <dependency> <groupId>com.githu

jsp中利用MySQL实现分页技术

分页是很常用的一种技术,而mysql中对于分页的操作也很简单,今天就说说如何在jsp页面中利用标签来最简化的实现分页: 链接:MySQL分页技术详解http://blog.csdn.net/u011637069/article/details/49928513 step1:编写DAO中代码: [java] view plain copy public List<Employee> findAll2(int page, int perPageRows) throws Exception { Li

EF 利用PagedList进行分页并结合查询 方法2

微软提供了PagedList分页,相信大家在网上也能搜索一大堆关于pagedList用法的博客,论坛.但是,在使用的过程中一不小心,就会掉入pagedList某种常规用法的陷阱. 我所说的某种常规用法是指如下方法(也可以参考我的博客:PagedList 分页用法): 代码如下: using System; using System.Collections.Generic; using System.Web; using System.Web.Mvc; using System.Linq; usi

Android开发之ListView利用OnScrollListener实现分页加载数据

上篇博文和大家分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现.

Django 利用 Pagination 简单分页

Django自身提供了一些类来实现管理分页,数据被分在不同的页面中,并带有"上一页/下一页"标签.这个类叫做Pagination,其定义位于 django/core/paginator.py 中. 一. Paginator类的解释 class Paginator(object): def __init__(self, object_list, per_page, orphans=0, allow_empty_first_page=True): self.object_list = ob

row_number() over order by与利用rownum查询分页效率分析

实际测试: 数据库:70万条数据 查询第10000页,每页10条.row_number() 耗时: 2.2秒rownum 耗时:1.3秒 查询第20000页,每页10条.row_number() 耗时: 4.5秒+rownum 耗时:3.8秒+ 网上看到的说,row_number()效率最高看来是没有经过大数据测试的. 本来还寄希望于row_number()分页代码简洁些,效率高些能优化现在系统的!让人失望了! 个人分析:新的分页方法(row_number() over(order by t.x

SSM框架利用自定义标签分页

分页通常是令人头疼的一件事,然而,这里将介绍一种新方法 这是一种巧妙地方法: 后端自定义JSP标签,这样在前端方面做分页会变得很简单 这里需要一种新技术:自定义标签 举例:在JSP动态页面技术中:我们都知道有c标签: 只需要在头导入: <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> 使用示例: <c:forEach items="${industry}&quo

php利用redis实现分页列表,新增,删除功能

在开发中经常遇到主页面大量数据加载,同时又不会经常改变的数据,每次从数据库里取数据对数据库的负荷非常大,然而将其放入到缓存内可以有效减轻数据库压力,提升页面加载速度. 1.基本连接方式实现: use Redis; 引入redis类 $this->redis = Redis::connection('email'); //连接 $basicKeys = 'emailList:'.$own['user_id']; //key可以根据自己需求进行更改 2.添加数据至redis缓存 $this->re

ASP.NET GridView利用PagerTemplate自定义分页

前端: <asp:GridView ID="GridView1" runat="server" AllowPaging="True"> <PagerTemplate> 当前第: <%--//((GridView)Container.NamingContainer)就是为了得到当前的控件--%> <asp:Label ID="LabelCurrentPage" runat="s