mssql access数据库利用top分页的方法
发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,这篇文章主要讲解了"mssql access数据库利用top分页的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mssql access数据库利用
千家信息网最后更新 2024年11月11日mssql access数据库利用top分页的方法
这篇文章主要讲解了"mssql access数据库利用top分页的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mssql access数据库利用top分页的方法"吧!
复制代码 代码如下:
uusing system.collections.generic;sing system;using system.text;////// 构造分页后的sql语句/// public static class paginghelper{ ////// 获取分页sql语句,排序字段需要构成唯一记录 /// /// 记录总数 /// 每页记录数 /// 当前页数 /// sql查询语句 /// 排序字段,多个则用","隔开 ///分页sql语句 public static string createpagingsql(int _recordcount, int _pagesize, int _pageindex, string _safesql, string _orderfield) { //重新组合排序字段,防止有错误 string[] arrstrorders = _orderfield.split(new char[] { ',' }, stringsplitoptions.removeemptyentries); stringbuilder sboriginalorder = new stringbuilder(); //原排序字段 stringbuilder sbreverseo教程rder = new stringbuilder(); //与原排序字段相反,用于分页 for (int i = 0; i < arrstrorders.length; i++) { arrstrorders[i] = arrstrorders[i].trim(); //去除前后空格 if (i != 0) { sboriginalorder.append(", "); sbreverseorder.append(", "); } sboriginalorder.append(arrstrorders[i]);int index = arrstrorders[i].indexof(" "); //判断是否有升降标识 if (index > 0) { //替换升降标识,分页所需 bool flag = arrstrorders[i].indexof(" desc", stringcomparison.ordinalignorecase) != -1; sbreverseorder.appendformat("{0} {1}", arrstrorders[i].remove(index), flag ? "asc" : "desc"); } else { sbreverseorder.appendformat("{0} desc", arrstrorders[i]); } }//计算总页数 _pagesize = _pagesize == 0 ? _recordcount : _pagesize; int pagecount = (_recordcount + _pagesize - 1) / _pagesize;//检查当前页数 if (_pageindex < 1) { _pageindex = 1; } else if (_pageindex > pagecount) { _pageindex = pagecount; }stringbuilder sbsql = new stringbuilder(); //第一页时,直接使用top n,而不进行分页查询 if (_pageindex == 1) { sbsql.appendformat(" select top {0} * ", _pagesize); sbsql.appendformat(" from ({0}) as t ", _safesql); sbsql.appendformat(" order by {0} ", sboriginalorder.tostring()); } //最后一页时,减少一个top n else if (_pageindex == pagecount) { sbsql.append(" select * from "); sbsql.append(" ( "); sbsql.appendformat(" select top {0} * ", _recordcount - _pagesize * (_pageindex - 1)); sbsql.appendformat(" from ({0}) as t ", _safesql); sbsql.appendformat(" order by {0} ", sbreverseorder.tostring()); sbsql.append(" ) as t "); sbsql.appendformat(" order by {0} ", sboriginalorder.tostring()); } //前半页数时的分页 else if (_pageindex < (pagecount / 2 + pagecount % 2)) { sbsql.append(" select * from "); sbsql.append(" ( "); sbsql.appendformat(" select top {0} * from ", _pagesize); sbsql.append(" ( "); sbsql.appendformat(" select top {0} * ", _pagesize * _pageindex); sbsql.appendformat(" from ({0}) as t ", _safesql); sbsql.appendformat(" order by {0} ", sboriginalorder.tostring()); sbsql.append(" ) as t "); sbsql.appendformat(" order by {0} ", sbreverseorder.tostring()); sbsql.append(" ) as t "); sbsql.appendformat(" order by {0} ", sboriginalorder.tostring()); } //后半页数时的分页 else { sbsql.appendformat(" select top {0} * from ", _pagesize); sbsql.append(" ( "); sbsql.appendformat(" select top {0} * ", ((_recordcount % _pagesize) + _pagesize * (pagecount - _pageindex))); sbsql.appendformat(" from ({0}) as t ", _safesql); sbsql.appendformat(" order by {0} ", sbreverseorder.tostring()); sbsql.append(" ) as t "); sbsql.appendformat(" order by {0} ", sboriginalorder.tostring()); }return sbsql.tostring(); }////// 获取记录总数sql语句 /// /// 限定记录数 /// sql查询语句 ///记录总数sql语句 public static string createtopnsql(int _n, string _safesql) { return string.format(" select top {0} * from ({1}) as t ", _n, _safesql); }////// 获取记录总数sql语句 /// /// sql查询语句 ///记录总数sql语句 public static string createcountingsql(string _safesql) { return string.format(" select count(1) as recordcount from ({0}) as t ", _safesql); }}
感谢各位的阅读,以上就是"mssql access数据库利用top分页的方法"的内容了,经过本文的学习后,相信大家对mssql access数据库利用top分页的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
语句
字段
总数
页数
排序
数据
数据库
方法
查询
学习
代码
内容
多个
就是
思路
情况
教程
文章
更多
标识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
四川超频服务器联系人
本地服务器的搭建
服务器如何卸载操作系统
网络安全法中被规定的禁止行为
网络安全督查自查情况
传统网络技术的特点
苹果手机出现联接服务器出错
新会优橙网络技术有限公司
网络安全属于哪个法律范畴
如何用合并邮件打印数据库
服务器镜像怎么选择
人大计算机数据库
正规的浪潮服务器服务商电话
非计算机专业做网络安全
重庆牛创网络技术有限公司
hp服务器改硬盘
网络安全靠人民为主题手抄报
黑龙江谷爱互联网科技有限公司
德温特数据库中有哪些国家
基层医院信息网络安全
电子政务网络安全形势分析
cmd如何连接数据库
我的世界畅玩pc服务器配置
绍兴app手机软件开发公司
沧州网络技术是什么
c4top网络技术挑战赛
gui如何连接数据库
网络安全主持稿结尾
网络安全的管理要求
学校网络安全宣传标语大全