sqlserver 分页查询

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不同之处在于前者返回的是分组里的每一条数据,并且可以对分组数据进行排序操作。后者只能返回聚合之后的组的数据统计值的记录。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值