文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 精品软件 | 下载排行 | 推荐下载 | 免费看大片 | WPS | 杀毒软件
清风网络
首 页 软件下载 网络学院 数码学院
QQ 电脑入门 游戏 操作系统 图形处理 办公软件 媒体动画 精文荟萃 工具软件 网络编程 程序开发 网络技术 认证考试 网站建设 文章专栏
当前位置:清风网络学院程序开发其他语言利用SqlDataAdapter进行分页
精品推荐
特别推荐
·控制面板知多少
·给你十条学习Ruby语言的理由
·分页管理机制
·Perl 语言的重要价值体现
·经验技巧:分享两条Delphi开发经验
·Java编程思想:面向对象的逻辑思维方法
·Samba系统简介
热点TOP10
·AIX 5L 学习大纲/简易教程(2)(未经许可,请勿COPY)
·DENX U-Boot及Linux使用手册
·EZ-USB 68013A开发指南
·图象处理中的边缘检测------canny算子
·Visual C++ ADO数据库编程入门
·利用 wordXP 实现自动排班
·UDT协议-基于UDP的可靠数据传输协议
·XPCOM--LINUX下的组件开发技术
·MyEclipse JSF 快速入门中文版(上)
·samba和openldap结合实战
·AIX 5L 学习大纲/简易教程(1)(未经许可,请勿COPY)
·Microsoft Windows XP Embedded 开发工具概述
·eMbedded Visual C++开发入门
·在VC6中创建wxWidgets项目[附图]
·数值计算程序大放送-线性代数方程组
·列表视图控件
·visual studio 2005 简体中文团队开发版 SQL server 2005简体中文版下载
·Visual Studio 2005:在 Visual C++ 中开发自定义的绘图控件
·汇编语言工具下载
·多文档界面(MDI)

利用SqlDataAdapter进行分页

日期:2007年5月2日 作者: 查看:[大字体 中字体 小字体]


利用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
  }


[1] [2] 下一页 




上一篇:深入浅出之正则表达式

下一篇:在Pocket PC上编写游戏之一

利用SqlDataAdapter进行分页 相关文章:
·如何进行局域网设置
·asp.net(C#)海量数据表高效率分页算法(易懂,不使用存储过程)
·一个Struts实现分页,增删改查,Tiles,国际化的DEMO
·吉林换妻俱乐部 须进行视频验证(图)
·利用腾讯漏洞取回QQ密码
·C# GridView 排序及分页
·利用Google突破封锁:下载想要的东西
·目前最好的JSP分页技术(考虑到数据库移植,并修正过效率)
·在 C++ Builder中利用串行通信控件编程
·利用word将PDF转换DOC文件的方法
利用SqlDataAdapter进行分页 相关软件:
·利用IE修复专家突破网吧的多重限制
·野蛮合租进行时
·如何进行上市公司财务分析及公告解读
·使用期PowerDesigner进行数据建模
·关于对《中华人民共和国进出口税则》的税目、税率进行调整
·《魔兽世界》部落屠龙进行曲视频
·使用WAS对Web应用程序进行负载测试
·代理跳板的简单制作与利用
·利用留言簿获得大量webshell
·痛快进行曲

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.vipcn.net
| 帮助(?) | 版权声明 | 友情连接 | 关于我们 | 信息发布
Copyright 2007 www.vipcn.net All Rights Reserved. 鄂ICP备05000083号Powered by:viphot