首页 > 资讯列表 > 编程/数据库 >> 数据库操作教程

SQLServer2012  开窗函数

数据库操作教程 2022-09-23 18:17:46 转载来源: 网络整理/侵权必删

废话不多说了,直接给大家贴代码了,具体代码如下所示:--开窗函数:在结果集的基础上进一步处理(聚合操作)--Over函数,添加一个字段显示最大年龄SELECT*,MAX(StuAge)OVER()MaxStuAgeFROMdbo.Student;--Over函数,添加一个字段显示总人数SELECT*,COUNT(StuID)OVER()StuCountFROMdbo

废话不多说了,直接给大家贴代码了,具体代码如下所示:

-- 开窗函数:在结果集的基础上进一步处理(聚合操作)-- Over函数,添加一个字段显示最大年龄SELECT * ,    MAX(StuAge) OVER ( ) MaxStuAgeFROM  dbo.Student;-- Over函数,添加一个字段显示总人数SELECT * ,    COUNT(StuID) OVER ( ) StuCountFROM  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 ( ) AgeHeightFROM  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  开窗函数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

标签: nbsp SQLServer2012 开窗 函数


声明:本文内容来源自网络,文字、图片等素材版权属于原作者,平台转载素材出于传递更多信息,文章内容仅供参考与学习,切勿作为商业目的使用。如果侵害了您的合法权益,请您及时与我们联系,我们会在第一时间进行处理!我们尊重版权,也致力于保护版权,站搜网感谢您的分享!

站长搜索

http://www.adminso.com

Copyright @ 2007~2024 All Rights Reserved.

Powered By 站长搜索

打开手机扫描上面的二维码打开手机版


使用手机软件扫描微信二维码

关注我们可获取更多热点资讯

站长搜索目录系统技术支持