分享
 
 
 

利用SqlDataAdapter进行记录分页

王朝mssql·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

说到分页,很多地方都会用到,不管是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了

这样,初级的分页就完成了

但这样写代码很烦琐,看以后能不能写成一个自定义控件.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有