千家信息网

SQL Server分页的方法有哪些

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,这篇文章主要介绍了SQL Server分页的方法有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SQL Server分页的方法有哪些文章都会有所收获,下面我们一起来看
千家信息网最后更新 2024年09月22日SQL Server分页的方法有哪些

这篇文章主要介绍了SQL Server分页的方法有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SQL Server分页的方法有哪些文章都会有所收获,下面我们一起来看看吧。

方法一:(最常用的分页代码, top / not in)

SELECT   TOP 3 [SalesOrderID], [RevisionNumber], [OrderDate]FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader]WHERE    [SalesOrderID] NOT IN (   SELECT   TOP 15 [SalesOrderID]                                    FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader]                                    ORDER BY [SalesOrderID] ) ORDER BY SalesOrderID;

备注: 注意前后的order by 一致

方法二:排名开窗函数 (row_number() over (order by ))

SELECT  [SalesOrderID], [RevisionNumber], [OrderDate]FROM    (   SELECT [SalesOrderID], [RevisionNumber], [OrderDate] ,                   ROW_NUMBER() OVER ( ORDER BY SalesOrderID ) AS rowid            FROM   [AdventureWorks2012].[Sales].[SalesOrderHeader] ) cteWHERE   rowidBETWEEN 16 AND 18;

方法三:(offset /fetch next, SQL Server 2012支持,性能最好!)

SELECT   [SalesOrderID], [RevisionNumber], [OrderDate] FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader] ORDER BY SalesOrderID OFFSET 15 ROW FETCH NEXT 3 ROWS ONLY;

总结:利用变量进行分页

DECLARE @page INT, @size INT, @Total INT;SELECT @page = 3, @size = 10; --当前页面为3,页面大小为10-------方法一SELECT   TOP ( @size ) [SalesOrderID], [RevisionNumber], [OrderDate]FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader]WHERE    [SalesOrderID] NOT IN (   SELECT   TOP (( @page - 1 ) * @size ) [SalesOrderID]                                   FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader]                                   ORDER BY [SalesOrderID] )ORDER BY SalesOrderID;-------方法二SELECT  [SalesOrderID], [RevisionNumber], [OrderDate]FROM    (   SELECT [SalesOrderID], [RevisionNumber], [OrderDate] ,                   ROW_NUMBER() OVER ( ORDER BY SalesOrderID ) AS rowid            FROM   [AdventureWorks2012].[Sales].[SalesOrderHeader] ) cteWHERE   rowidBETWEEN ( @page - 1 ) * @size + 1 AND @page * @size;-------方法三SELECT   [SalesOrderID], [RevisionNumber], [OrderDate]FROM     [AdventureWorks2012].[Sales].[SalesOrderHeader]ORDER BY SalesOrderID OFFSET ( @page - 1 ) * @size ROWS FETCH NEXT @size ROWS ONLY; ---offset的当前页面是从零开

关于"SQL Server分页的方法有哪些"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"SQL Server分页的方法有哪些"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。

0