-- 开窗函数:在结果集的基础上进一步处理(聚合操作)

SELECT * FROM dbo.Student

S#         Sname      Sage                    Ssex
---------- ---------- ----------------------- ----------
01 赵雷 1990-01-01 00:00:00.000
02 钱电 1990-12-21 00:00:00.000
03 孙风 1990-05-20 00:00:00.000
04 李云 1990-08-06 00:00:00.000
05 周梅 1991-12-01 00:00:00.000
06 吴兰 1992-03-01 00:00:00.000
07 郑竹 1989-07-01 00:00:00.000
08 王菊 1990-01-20 00:00:00.000 女 -- Over函数,添加一个字段显示最大年龄
SELECT *,MAX(DATEDIFF(yyyy,Sage,GETDATE()))OVER() MaxSage FROM dbo.Student S# Sname Sage Ssex MaxSage
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.00028
02 钱电 1990-12-21 00:00:00.00028
03 孙风 1990-05-20 00:00:00.00028
04 李云 1990-08-06 00:00:00.00028
05 周梅 1991-12-01 00:00:00.00028
06 吴兰 1992-03-01 00:00:00.00028
07 郑竹 1989-07-01 00:00:00.00028
08 王菊 1990-01-20 00:00:00.00028 -- Over函数,添加一个字段显示总人数
SELECT *,COUNT(S#)OVER() 总人数 FROM dbo.Student S# Sname Sage Ssex 总人数
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.0008
02 钱电 1990-12-21 00:00:00.0008
03 孙风 1990-05-20 00:00:00.0008
04 李云 1990-08-06 00:00:00.0008
05 周梅 1991-12-01 00:00:00.0008
06 吴兰 1992-03-01 00:00:00.0008
07 郑竹 1989-07-01 00:00:00.0008
08 王菊 1990-01-20 00:00:00.0008 -- Partition By 分组统计数量
-- 根据性别分组后,统计
SELECT *,COUNT(*) OVER(PARTITION BY Ssex) 总数 FROM dbo.Student S# Sname Sage Ssex 总数
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.0004
02 钱电 1990-12-21 00:00:00.0004
03 孙风 1990-05-20 00:00:00.0004
04 李云 1990-08-06 00:00:00.0004
05 周梅 1991-12-01 00:00:00.0004
06 吴兰 1992-03-01 00:00:00.0004
07 郑竹 1989-07-01 00:00:00.0004
08 王菊 1990-01-20 00:00:00.0004 -- 根据性别分组后,统计、排序
SELECT *,COUNT(*) OVER(PARTITION BY Ssex ORDER BY Sname) 序号 FROM dbo.Student S# Sname Sage Ssex 序号
---------- ---------- ----------------------- ---------- -----------
04 李云 1990-08-06 00:00:00.0001
02 钱电 1990-12-21 00:00:00.0002
03 孙风 1990-05-20 00:00:00.0003
01 赵雷 1990-01-01 00:00:00.0004
08 王菊 1990-01-20 00:00:00.0001
06 吴兰 1992-03-01 00:00:00.0002
07 郑竹 1989-07-01 00:00:00.0003
05 周梅 1991-12-01 00:00:00.0004 -- Over函数,添加一个字段显示平均年龄
SELECT *,AVG(DATEDIFF(yyyy,Sage,GETDATE()))OVER() 平均年龄 FROM dbo.Student S# Sname Sage Ssex 平均年龄
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.00026
02 钱电 1990-12-21 00:00:00.00026
03 孙风 1990-05-20 00:00:00.00026
04 李云 1990-08-06 00:00:00.00026
05 周梅 1991-12-01 00:00:00.00026
06 吴兰 1992-03-01 00:00:00.00026
07 郑竹 1989-07-01 00:00:00.00026
08 王菊 1990-01-20 00:00:00.00026 --Row_Rumber()
SELECT *,ROW_NUMBER()OVER(ORDER BY S# DESC) 序号 FROM dbo.Student S# Sname Sage Ssex 序号
---------- ---------- ----------------------- ---------- --------------------
08 王菊 1990-01-20 00:00:00.0001
07 郑竹 1989-07-01 00:00:00.0002
06 吴兰 1992-03-01 00:00:00.0003
05 周梅 1991-12-01 00:00:00.0004
04 李云 1990-08-06 00:00:00.0005
03 孙风 1990-05-20 00:00:00.0006
02 钱电 1990-12-21 00:00:00.0007
01 赵雷 1990-01-01 00:00:00.0008 --Row_Rumber() 实现分页效果
WITH T AS (
SELECT ROW_NUMBER() OVER ( ORDER BY S# DESC ) RowNumber ,*
FROM dbo.Student
)
SELECT * FROM T WHERE T.RowNumber BETWEEN 1 AND 3 RowNumber S# Sname Sage Ssex
-------------------- ---------- ---------- ----------------------- ----------
1 08 王菊 1990-01-20 00:00:00.000
2 07 郑竹 1989-07-01 00:00:00.000
3 06 吴兰 1992-03-01 00:00:00.000 女 --Rank() 排名函数,名次相同,跳过
SELECT *,RANK()OVER(ORDER BY Ssex) 名次 FROM dbo.Student
S# Sname Sage Ssex 名次
---------- ---------- ----------------------- ---------- --------------------
01 赵雷 1990-01-01 00:00:00.0001
02 钱电 1990-12-21 00:00:00.0001
03 孙风 1990-05-20 00:00:00.0001
04 李云 1990-08-06 00:00:00.0001
05 周梅 1991-12-01 00:00:00.0005
06 吴兰 1992-03-01 00:00:00.0005
07 郑竹 1989-07-01 00:00:00.0005
08 王菊 1990-01-20 00:00:00.0005 --DENSE_Rank() 排名函数,名次相同不跳过
SELECT *,DENSE_RANK()OVER(ORDER BY Ssex) 名次 FROM dbo.Student S# Sname Sage Ssex 名次
---------- ---------- ----------------------- ---------- --------------------
01 赵雷 1990-01-01 00:00:00.0001
02 钱电 1990-12-21 00:00:00.0001
03 孙风 1990-05-20 00:00:00.0001
04 李云 1990-08-06 00:00:00.0001
05 周梅 1991-12-01 00:00:00.0002
06 吴兰 1992-03-01 00:00:00.0002
07 郑竹 1989-07-01 00:00:00.0002
08 王菊 1990-01-20 00:00:00.0002 -- NTILE()函数,参数:记录总数/划分区域 = 每个区域数组,把记录序号放进数组 (平均分组)
SELECT *,NTILE(3)OVER(ORDER BY Ssex) 区域 FROM dbo.Student S# Sname Sage Ssex 区域
---------- ---------- ----------------------- ---------- --------------------
01 赵雷 1990-01-01 00:00:00.0001
02 钱电 1990-12-21 00:00:00.0001
03 孙风 1990-05-20 00:00:00.0001
04 李云 1990-08-06 00:00:00.0002
05 周梅 1991-12-01 00:00:00.0002
06 吴兰 1992-03-01 00:00:00.0002
07 郑竹 1989-07-01 00:00:00.0003
08 王菊 1990-01-20 00:00:00.0003

SQL Server - 开窗函数的更多相关文章

  1. SQL ServerOVER 子句,over开窗函数,SQL SERVER 开窗函数

    https://technet.microsoft.com/zh-cn/library/ms189461(v=sql.105).aspx http://www.cnblogs.com/85538649 ...

  2. 【转】SQL SERVER 开窗函数简介

    在SQL SERVER 2005/2008支持两种排名开窗函数和聚集开窗函数. 以SQL SERVER中分面页为例,按时间顺序列出定单号. WITH OrderInfo AS ( SELECT ROW ...

  3. SQL SERVER开窗函数

    作为一名开发人员来讲,我感觉在职场白混了好多年,可能是自己真的没有进取的精神吧,看了<程序员的SQL金典>这本电子书,真的让我学到了不少知识,真心喜欢这本电子书,书中讲解的内容比较好懂,也 ...

  4. Sql server 开窗函数over()的语法

    用法一:与ROW_NUMBER()函数结合用,给结果进行排序编号,如图: 代码如下: SELECT ROW_NUMBER() over(order by RequiredDate) num ,* fr ...

  5. Sql Server 开窗函数Over()的使用

    利用over(),将统计信息计算出来,然后直接筛选结果集 declare @t table( ProductID int, ProductName ), ProductType ), Price in ...

  6. SQL Server开窗函数之OVER子句、PARTITION BY 子句

    开窗函数与聚合函数一样,都是对行的集合组进行聚合计算.它用于为行定义一个窗口(这里的窗口是指运算将要操作的行的集合),它对一组值进行操作,不需要使用GROUP BY子句对数据进行分组,能够在同一行中同 ...

  7. SQL Server 聚合函数算法优化技巧

    Sql server聚合函数在实际工作中应对各种需求使用的还是很广泛的,对于聚合函数的优化自然也就成为了一个重点,一个程序优化的好不好直接决定了这个程序的声明周期.Sql server聚合函数对一组值 ...

  8. SQL Server排序函数row_number和rank的区别

    SQL Server排序函数row_number和rank的区别 直接看测试结果 declare @table table(name varchar(100),amount int, memo var ...

  9. 数据库开发基础-SQl Server 聚合函数、数学函数、字符串函数、时间日期函数

    SQL 拥有很多可用于计数和计算的内建函数. 函数的语法 内建 SQL 函数的语法是: SELECT function(列) FROM 表 函数的类型 在 SQL 中,基本的函数类型和种类有若干种.函 ...

随机推荐

  1. 单片机程序在内存和FLASH中的空间分配

    本文转载于的tietao的博客!!!http://blog.csdn.net/tietao/article/details/8172411 *******防止自己忘记,固备之. 一句话:基于速度问题, ...

  2. Kubernetes学习之路(二十五)之Helm程序包管理器

    目录 1.Helm的概念和架构 2.部署Helm (1)下载helm (2)部署Tiller 3.helm的使用 4.chart 目录结构 5.chart模板 6.定制安装MySQL chart (1 ...

  3. TMS320VC5509驱动74HC595芯片

    1. 5509A有3个MCBSP模块,其中模块MCBSP可以配置成SPI模式,不过实际使用的时候需要把CLKX1和CLKR1接在一起,暂时没搞明白原因 MCBSP有6个引脚,DR0 RX0 作为数据的 ...

  4. 纯 CSS 解决自定义 CheckBox 背景颜色问题

    CodePen 需要使用色 #ec6337(当然可以是任意颜色),解决问题:记住密码定制 CheckBox,解释全在注释里 主要使用到 ::before 或 ::after 伪类处理,伪装成内部的那个 ...

  5. 用C语言操作MySQL数据库,进行连接、插入、修改、删除等操作

    C/C++ code   ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 3 ...

  6. 记录:TensorFlow 中的 padding 方式

    TensorFlow 中卷积操作和池化操作中都有一个参数 padding,其可选值有 ['VALID', 'SAME']. 在 TensorFlow 文档中只是给出了输出张量的维度计算方式,但是并没有 ...

  7. 一种C#泛型方法在lua中表示的设计

    在进行lua方法注册的时候, 大多数解决方案直接否定了泛型方法, 因为在lua侧难以表达出泛型, 以及lua的函数重载问题, 函数重载问题可以通过一些特殊方法解决, 而泛型问题是主要问题, 以Unit ...

  8. 粒子群算法(PSO)算法解析(简略版)

    粒子群算法(PSO) 1.粒子群算法(PSO)是一种基于群体的随机优化技术: 初始化为一组随机解,通过迭代搜寻最优解. PSO算法流程如图所示(此图是从PPT做好,复制过来的,有些模糊) 2.PSO模 ...

  9. TimelineJS JSON 数据格式 - 译文 [原创]

    TimelineJS 是用于绘制时间轴的 Javascript 开源脚本,目前是 TimelineJS3 版.参阅 https://github.com/NUKnightLab/TimelineJS3 ...

  10. Cloud Native Weekly | KubeCon首登中国,华为云亮相KubeCon 2018,微软云服务又罢工

    1.KubeCon首登中国,Kubernetes将如何再演进? 11月14日,由CNCF发起的云原生领域全球最大的峰会之一KubeCon+CloudNativeCon首次登陆中国,中国已经成为云原生领 ...