asp.Net
发布时间:2022-04-07 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Asp.net 通用万级数据分页代码[修正下载地址],大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
1.主题,Asp.net环境下,通用的数据分页(包括
Oracle,SqlServer,DB2...)
@R_
673_9980@,就想做一个通用点的数据分页组件,但苦于一直没有充足的时间,所以迟迟没有实现(当然,
主要是因为有一定的难度,要处理视图状态,回传事件,自绘等...),"十一"期间,陪女朋友去了躺"湘西",白天游山玩水,晚上无事,吃吃当地的夜宵,无聊之际,
GOOGLE了一把Oracle的数据分页,竟然没有一个完整的关于Asp.net +
Oracle数据分页的例子,要不就是有版本问题,索性决定自己弄一个.
2.环境
IDE;vs2008+asp.net2.0 or 3.0+
Oracle
9i Oracle测试数据;41万多条
带宽;网通说是有2M的带宽,其实TNND只有100多KB
3.原理
利用
Oracle
9i的RowNum获取我们想要的数据,如图3.1
public IEnumerable GetPageSqlBy
Oracle(
String sql,int startRowIndex,int maximumRows,
String orderBy)
{ String sqlFormat =
String.Format("
SELEct * from (
Select ROWNUM rn,pageTable.* from
{0} pageTable where rownum <=
{1}) where rn>
{2}",sql,startRowIndex + maximumRows,startRowInde
X);
return ydjw
OracleConn.RetriveDataSet(sqlFormat).Tables
[0].DefaultView;
}
startRowIndex表示开始索引,@H_832_23@maximumRows表示要获取的每页记录数目.
然后把分页后的数据绑定到ObjectDatasource组件,如下图
4.效果
4.1 支持多排序,比如时间,比如身份证明号码等
4.2 41万多条数据
4.3 单条件查询,第一次用时1.547秒
4.4 第二次,用时1.515秒
第三次差不多,就不贴了.
4.5 看看不带条件的查询,一次把41万条数据全部查询出来使用的时间
可以看到,不带条件查询41万条数据,第一次用时1.265秒.
4.6 可以看到不带条件查询41万条数据,第二次用时1.156秒
4.7 可用SqlServer,或者
DB2等数据库代替,只需要修改 图3.1获取数据的方法,其他地方不用动.
5.
需要注意的地方
5.1 记得数据量上万时,一定要加索引,否则要等得"花谢花开".
5.2 Ob
jectData
source的所有参数名称,一定要和绑定的
方法参数名称,顺序一致.
5.3 能用缓存的,尽量用缓存
5.4 SqlServer的分页算法,就不说了,替换一下图3.1的方法就行
5.5 因为
数据库文件实在太大,不方
便下载,有兴趣的朋友自己弄一张表就OK,加上webconfig中的数据库连接配置
6.下载
测试Demo下载
http://xiazai.jb51.net/200810/yuanma/TestDataBindControlls.rar 【已修正】
7.后话
该说的都说了,希望对大家能有所帮助启发,还有就是此测试Demo还没有加缓存,有兴趣的朋友可以加上,欢迎大家讨论,批评,指导...
大佬总结
以上是大佬教程为你收集整理的Asp.net 通用万级数据分页代码[修正下载地址]全部内容,希望文章能够帮你解决Asp.net 通用万级数据分页代码[修正下载地址]所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。