Welcome

首页 / 数据库 / SQLServer / SQL Server 2012开窗函数

废话不多说了,直接给大家贴代码了,具体代码如下所示:
-- 开窗函数:在结果集的基础上进一步处理(聚合操作)-- Over函数,添加一个字段显示最大年龄SELECT * ,MAX(StuAge) OVER ( ) MaxStuAgeFROMdbo.Student;-- Over函数,添加一个字段显示总人数SELECT * ,COUNT(StuID) OVER ( ) StuCountFROMdbo.Student;-- Partition By 分组统计数量-- 根据性别分组后,统计SELECT COUNT(*) OVER ( PARTITIONBY StuSex ) ,*FROMdbo.Student;-- 根据班级分组后,统计、排序SELECT COUNT(*) OVER ( PARTITIONBY Class ORDER BY Height) ,*FROMdbo.Student;-- Over函数,添加一个字段显示平均身高SELECT * ,AVG(Height) OVER ( ) AgeHeightFROMdbo.Student;--Row_Rumber()SELECT ROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber ,*FROMdbo.Student--Row_Rumber() 实现分页效果;WITHT AS ( SELECTROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber ,*FROM dbo.Student )SELECT *FROMTWHERET.RowNumber BETWEEN 1 AND 3;--Rank() 排名函数,名次相同,跳过SELECT RANK() OVER ( ORDER BY Height ) ,*FROMdbo.Student;--DENSE_Rank() 排名函数,名次相同不跳过SELECT DENSE_RANK() OVER ( ORDER BY Height ) ,*FROMdbo.Student;-- NTILE()函数,参数:记录总数/划分区域 = 每个区域数组,把记录序号放进数组 (平均分组)SELECT NTILE(3) OVER ( ORDER BY StuSex ) ,*FROMdbo.Student;
以上所述是小编给大家介绍的SQL Server 2012  开窗函数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!