网站首页 > 数据库 > MsSql 正文
废话不多说了,直接给大家贴代码了,具体代码如下所示:
-- 开窗函数:在结果集的基础上进一步处理(聚合操作) -- Over函数,添加一个字段显示最大年龄 SELECT * , MAX(StuAge) OVER ( ) MaxStuAge FROM dbo.Student; -- Over函数,添加一个字段显示总人数 SELECT * , COUNT(StuID) OVER ( ) StuCount FROM dbo.Student; -- Partition By 分组统计数量 -- 根据性别分组后,统计 SELECT COUNT(*) OVER ( PARTITION BY StuSex ) , * FROM dbo.Student; -- 根据班级分组后,统计、排序 SELECT COUNT(*) OVER ( PARTITION BY Class ORDER BY Height) , * FROM dbo.Student; -- Over函数,添加一个字段显示平均身高 SELECT * , AVG(Height) OVER ( ) AgeHeight FROM dbo.Student; --Row_Rumber() SELECT ROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber , * FROM dbo.Student --Row_Rumber() 实现分页效果 ; WITH T AS ( SELECT ROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber , * FROM dbo.Student ) SELECT * FROM T WHERE T.RowNumber BETWEEN 1 AND 3; --Rank() 排名函数,名次相同,跳过 SELECT RANK() OVER ( ORDER BY Height ) , * FROM dbo.Student; --DENSE_Rank() 排名函数,名次相同不跳过 SELECT DENSE_RANK() OVER ( ORDER BY Height ) , * FROM dbo.Student; -- NTILE()函数,参数:记录总数/划分区域 = 每个区域数组,把记录序号放进数组 (平均分组) SELECT NTILE(3) OVER ( ORDER BY StuSex ) , * FROM dbo.Student;
以上所述是小编给大家介绍的SQL Server 2012 开窗函数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
猜你喜欢
- 2021-07-16 Oracle 中 decode 函数用法
- 2021-07-16 Oracle生成不重复票号与LPAD,RPAD与NEXTVAL函数解析
- 2021-07-16 系统隐形杀手――阻塞与等待(SQL)
- 2021-07-16 SQL Server 2012 多表连接查询功能实例代码
- 2021-07-16 sql server2016里面的json功能浅析
- 2021-07-16 SQL查询中需要使用别名问题
- 2021-07-16 SQL Server 聚焦存储过程性能优化、数据压缩和页压缩提高IO性能方法(一)
- 2021-07-16 SQL去除重复记录(七种)
- 2021-07-16 MSSQLSERVER不同版本设置开启远程连接(sa配置)
- 2021-07-16 sql server实现递归查询的方法示例
本文暂时没有评论,来添加一个吧(●'◡'●)