首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >针对SQL Server的动态复杂查询的分页

针对SQL Server的动态复杂查询的分页
EN

Stack Overflow用户
提问于 2012-09-13 21:21:48
回答 1查看 549关注 0票数 0

我找不到一种简单的方法来对SQL server的复杂查询进行分页。我需要编写以sql查询为参数的函数(此查询可以包含子查询、order by语句、分组等)。并检索结果的特定页面。在oracle中,用另一个select语句封装这类查询很容易,但对于SQL server,我找不到任何类似方法。我想要避免的是解析输入SQL语句。我使用的是SQL server 2005。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-13 21:30:22

在SQL Server2005及更高版本中,分页最好通过排名函数来完成。然而,鉴于任意SQL查询是未排序的,您需要以某种方式指定排序应该是什么才能使其工作,这与您试图实现的通用解决方案并不真正“兼容”(*)。

建议的方法如下(假设变量@PageSize包含每页的项目数,@Page作为您要检索的页面的基于1的索引):

代码语言:javascript
复制
WITH NumberedQuery AS (
  SELECT ROW_NUMBER() OVER (ORDER BY q.SomeColumn) ix, q.*
  FROM QueryToPage q
)
SELECT nq.*
  FROM NumberedQuery nq
  WHERE (nq.ix >= (@Page-1)*@PageSize) AND (nq.ix < @Page*@PageSize);

(*):您的连接SQL代码的方法有几个问题,它阻止了参数化查询的使用,它增加了SQL注入的风险,它损害了性能,如果顺序未指定,它无法解决手头的问题。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12407307

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档