mssql access数据库利用top分页的方法
发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,这篇文章主要讲解了"mssql access数据库利用top分页的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mssql access数据库利用
千家信息网最后更新 2024年09月22日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安全错误
数据库的锁怎样保障安全
甘谷服务器
asp恢复数据库 正在使用
欧盟iot的网络安全法规
软件开发员怎么画
关于网络安全简单海报
河北项目软件开发价格表
上海古松软件开发限公司
数据库表在哪个文件夹
数据库创建的索引不起作用
湘潭软件开发培训学校电话
软件开发都有哪些模式
网络安全人员是什么编制
网络安全2022手抄报
国泰君安数据库使用
反编译 查看手游数据库
python数据库项目打包
数据库查数据速度慢怎么办
TradingView自己服务器
wildfly管理服务器
上海亨嘉网络技术最新招聘
hadoop的数据库
新型网络技术对宪法的影响
软件开发工程师证难考吗
什么是科技互联网金融
玉环租房网络安全
我的世界点赞量最多网易版服务器
软件开发都有哪些模式
阿里云服务器真的好吗
云服务器2核4g相当于什么电脑
大华evs服务器怎么取消重启