大连网站开发需要多少钱,大气 网站源码,miui稳定版到开发版的升级一般通过,凌云网站数据库只所以要分页查询#xff0c;其实是界面显示的需要#xff0c;不是数据库的需要。 数据库本身查询是很快的。本文章是针对这种情况的。 如果数据库本身查询慢#xff0c;那是优化查询语句的事情了。不在本文章范围内。
今天遇到了这个问题。 是个老项目。在原有的查询…数据库只所以要分页查询其实是界面显示的需要不是数据库的需要。 数据库本身查询是很快的。本文章是针对这种情况的。 如果数据库本身查询慢那是优化查询语句的事情了。不在本文章范围内。
今天遇到了这个问题。 是个老项目。在原有的查询的基础上分页查询提高显示效率。
1、尽量不作大的修改。 2、假设界面每页显示 1000 条数据。 3、下面 %sql% 可以是简单的表名也可以是复杂的查询语句 4、datetime 数据库排序字段。一般是最新的记录显示在最前面这里用时间字段(降序)
第一页 select top 1000 * from (%sql%) order by datetime desc
最末页 用记录总数 mod 1000计算出最末页要显示的记录个数。如果余数为0那就是1000 条。否则就是余数 N。 select * from ( select top N * from (%sql%) A order by datetime) B order by datetime desc 原理先升序查询数据然后取出最前面的 N 条记录就是最后一页要显示的 N 条记录了。再按降序排序。
中间页 有了上面最末页的思路中间页也很容易实现了。
select * from (select top 1000 * from (select top 1000 * intPageIndex from (%sql%) A order by datetime desc) B order by datetime) C order by datetime desc
intPageIndex 为第几页。 原理和最末页的查询是一样的。 比如显示第5页先按降序取出前 5000 条数据再从这 5000 条数据中取出最后的 1000 条就是第5页要显示的数据了。
是不是很简单。