具有大量记录的Sql Server分页
Posted
技术标签:
【中文标题】具有大量记录的Sql Server分页【英文标题】:Sql Server Pagening with large amount of records 【发布时间】:2014-08-29 12:40:56 【问题描述】:我有这个用于分页的 SQL 查询:
SELECT * FROM
(
SELECT T1.*,T2.*, ROW_NUMBER() over(ORDER BY ID DESC) row
FROM
table1 t1
LEFT JOIN
table2 t2 on t1.id = t2.pid
) tbl
WHERE row>= @start and row<@end
现在的问题是选择结果可以是数千条记录,这些记录将针对每个用户的每个页面执行。
任何建议我可以部分选择(选择更少的记录?)
ROW_NUMBER 可能按 ID 或 DATE 排序。
顺便说一句,选择 * 只是为了简化示例代码。
【问题讨论】:
您使用的是什么版本的 SQL Server? 这些答案有帮助吗? ***.com/questions/4358253/… 【参考方案1】:如果您有 SQL Server 2012 或更高版本,则可以使用 Offset 和 Fetch 关键字,如 here 所述
【讨论】:
如他没有写在 cmets 中的那样;) 好吧,我也许可以使用sql server 2012,性能是我的首要任务以上是关于具有大量记录的Sql Server分页的主要内容,如果未能解决你的问题,请参考以下文章