1.分页查询
ROW_NUMBER() OVER(ORDER BY COLUMMS)
IF OBJECT_ID('SysLogInfo','u') IS NULL --不存在用户表
BEGIN
CREATE TABLE SysLogInfo(
ID NVARCHAR(50) NOT NULL PRIMARY KEY,
Name NVARCHAR(50) NULL,
OldName NVARCHAR(50) NULL
)
INSERT INTO dbo.SysLogInfo( ID, Name, OldName )
VALUES ( '1','张三','张二'),
( '2','李四','张二'),
( '3','赵武','赵六'),
( '4','钱7','赵六')
END
--分页查询
DECLARE @page INT =1
DECLARE @pageSize INT =2
SELECT ID,Name,OldName FROM (
SELECT *,ROW_NUMBER() OVER (ORDER BY ID asc) row FROM dbo.SysLogInfo) a
WHERE row BETWEEN (@page-1)*@pageSize + 1 AND @page * @pageSize
结果:
2.ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2)
可以返回一个分组的多条记录
SELECT *,ROW_NUMBER() OVER (PARTITION BY OldName ORDER BY ID ) COUNT
FROM dbo.SysLogInfo
结果:
partition by关键字是分析性函数的一部分,它和聚合函数(如group by)不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录。
partition by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组。
partition by 与group by不同之处在于前者返回的是分组里的每一条数据,并且可以对分组数据进行排序操作。后者只能返回聚合之后的组的数据统计值的记录。