mssql access数据库利用top分页的方法
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,这篇文章主要讲解了"mssql access数据库利用top分页的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mssql access数据库利用
千家信息网最后更新 2025年02月05日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安全错误
数据库的锁怎样保障安全
计算机网络安全信息探究
广州安卓应用软件开发公司哪家强
网络安全手抄报图片很难
网络安全 表情包
软件开发会战口号
知网查重的外文数据库
加载数据库数据生成js
宽带连接管理器服务器
网络安全中的机密性内涵
辽阳辽阳网络技术求职
黑龙江网络技术转让
陕西土地gis系统软件开发公司
内存数据库和配置文件
网络安全禁毒知识答题竞赛
ss代理服务器购买
服务器怎么安全配置
明日之后更新服务器会有什么
阿里服务器个人网站也要备案吗
富士康软件开发级别
北仑计算机软件开发项目
2018互联网科技类公司
科技创新软件开发合同
金山区多功能软件开发案例
长沙正宇软件开发有限公司
怀旧服服务器武器装备
数据库多表查询怎么连接3个表
原神手游有不同服务器
学计算机网络技术赚钱吗
有哪些是软件开发
服务器安全模式怎么恢复