SQL Server - 开窗函数
-- 开窗函数:在结果集的基础上进一步处理(聚合操作) 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.000 男 28
02 钱电 1990-12-21 00:00:00.000 男 28
03 孙风 1990-05-20 00:00:00.000 男 28
04 李云 1990-08-06 00:00:00.000 男 28
05 周梅 1991-12-01 00:00:00.000 女 28
06 吴兰 1992-03-01 00:00:00.000 女 28
07 郑竹 1989-07-01 00:00:00.000 女 28
08 王菊 1990-01-20 00:00:00.000 女 28 -- Over函数,添加一个字段显示总人数
SELECT *,COUNT(S#)OVER() 总人数 FROM dbo.Student S# Sname Sage Ssex 总人数
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.000 男 8
02 钱电 1990-12-21 00:00:00.000 男 8
03 孙风 1990-05-20 00:00:00.000 男 8
04 李云 1990-08-06 00:00:00.000 男 8
05 周梅 1991-12-01 00:00:00.000 女 8
06 吴兰 1992-03-01 00:00:00.000 女 8
07 郑竹 1989-07-01 00:00:00.000 女 8
08 王菊 1990-01-20 00:00:00.000 女 8 -- Partition By 分组统计数量
-- 根据性别分组后,统计
SELECT *,COUNT(*) OVER(PARTITION BY Ssex) 总数 FROM dbo.Student S# Sname Sage Ssex 总数
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.000 男 4
02 钱电 1990-12-21 00:00:00.000 男 4
03 孙风 1990-05-20 00:00:00.000 男 4
04 李云 1990-08-06 00:00:00.000 男 4
05 周梅 1991-12-01 00:00:00.000 女 4
06 吴兰 1992-03-01 00:00:00.000 女 4
07 郑竹 1989-07-01 00:00:00.000 女 4
08 王菊 1990-01-20 00:00:00.000 女 4 -- 根据性别分组后,统计、排序
SELECT *,COUNT(*) OVER(PARTITION BY Ssex ORDER BY Sname) 序号 FROM dbo.Student S# Sname Sage Ssex 序号
---------- ---------- ----------------------- ---------- -----------
04 李云 1990-08-06 00:00:00.000 男 1
02 钱电 1990-12-21 00:00:00.000 男 2
03 孙风 1990-05-20 00:00:00.000 男 3
01 赵雷 1990-01-01 00:00:00.000 男 4
08 王菊 1990-01-20 00:00:00.000 女 1
06 吴兰 1992-03-01 00:00:00.000 女 2
07 郑竹 1989-07-01 00:00:00.000 女 3
05 周梅 1991-12-01 00:00:00.000 女 4 -- Over函数,添加一个字段显示平均年龄
SELECT *,AVG(DATEDIFF(yyyy,Sage,GETDATE()))OVER() 平均年龄 FROM dbo.Student S# Sname Sage Ssex 平均年龄
---------- ---------- ----------------------- ---------- -----------
01 赵雷 1990-01-01 00:00:00.000 男 26
02 钱电 1990-12-21 00:00:00.000 男 26
03 孙风 1990-05-20 00:00:00.000 男 26
04 李云 1990-08-06 00:00:00.000 男 26
05 周梅 1991-12-01 00:00:00.000 女 26
06 吴兰 1992-03-01 00:00:00.000 女 26
07 郑竹 1989-07-01 00:00:00.000 女 26
08 王菊 1990-01-20 00:00:00.000 女 26 --Row_Rumber()
SELECT *,ROW_NUMBER()OVER(ORDER BY S# DESC) 序号 FROM dbo.Student S# Sname Sage Ssex 序号
---------- ---------- ----------------------- ---------- --------------------
08 王菊 1990-01-20 00:00:00.000 女 1
07 郑竹 1989-07-01 00:00:00.000 女 2
06 吴兰 1992-03-01 00:00:00.000 女 3
05 周梅 1991-12-01 00:00:00.000 女 4
04 李云 1990-08-06 00:00:00.000 男 5
03 孙风 1990-05-20 00:00:00.000 男 6
02 钱电 1990-12-21 00:00:00.000 男 7
01 赵雷 1990-01-01 00:00:00.000 男 8 --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.000 男 1
02 钱电 1990-12-21 00:00:00.000 男 1
03 孙风 1990-05-20 00:00:00.000 男 1
04 李云 1990-08-06 00:00:00.000 男 1
05 周梅 1991-12-01 00:00:00.000 女 5
06 吴兰 1992-03-01 00:00:00.000 女 5
07 郑竹 1989-07-01 00:00:00.000 女 5
08 王菊 1990-01-20 00:00:00.000 女 5 --DENSE_Rank() 排名函数,名次相同不跳过
SELECT *,DENSE_RANK()OVER(ORDER BY Ssex) 名次 FROM dbo.Student S# Sname Sage Ssex 名次
---------- ---------- ----------------------- ---------- --------------------
01 赵雷 1990-01-01 00:00:00.000 男 1
02 钱电 1990-12-21 00:00:00.000 男 1
03 孙风 1990-05-20 00:00:00.000 男 1
04 李云 1990-08-06 00:00:00.000 男 1
05 周梅 1991-12-01 00:00:00.000 女 2
06 吴兰 1992-03-01 00:00:00.000 女 2
07 郑竹 1989-07-01 00:00:00.000 女 2
08 王菊 1990-01-20 00:00:00.000 女 2 -- NTILE()函数,参数:记录总数/划分区域 = 每个区域数组,把记录序号放进数组 (平均分组)
SELECT *,NTILE(3)OVER(ORDER BY Ssex) 区域 FROM dbo.Student S# Sname Sage Ssex 区域
---------- ---------- ----------------------- ---------- --------------------
01 赵雷 1990-01-01 00:00:00.000 男 1
02 钱电 1990-12-21 00:00:00.000 男 1
03 孙风 1990-05-20 00:00:00.000 男 1
04 李云 1990-08-06 00:00:00.000 男 2
05 周梅 1991-12-01 00:00:00.000 女 2
06 吴兰 1992-03-01 00:00:00.000 女 2
07 郑竹 1989-07-01 00:00:00.000 女 3
08 王菊 1990-01-20 00:00:00.000 女 3
SQL Server - 开窗函数的更多相关文章
- SQL ServerOVER 子句,over开窗函数,SQL SERVER 开窗函数
https://technet.microsoft.com/zh-cn/library/ms189461(v=sql.105).aspx http://www.cnblogs.com/85538649 ...
- 【转】SQL SERVER 开窗函数简介
在SQL SERVER 2005/2008支持两种排名开窗函数和聚集开窗函数. 以SQL SERVER中分面页为例,按时间顺序列出定单号. WITH OrderInfo AS ( SELECT ROW ...
- SQL SERVER开窗函数
作为一名开发人员来讲,我感觉在职场白混了好多年,可能是自己真的没有进取的精神吧,看了<程序员的SQL金典>这本电子书,真的让我学到了不少知识,真心喜欢这本电子书,书中讲解的内容比较好懂,也 ...
- Sql server 开窗函数over()的语法
用法一:与ROW_NUMBER()函数结合用,给结果进行排序编号,如图: 代码如下: SELECT ROW_NUMBER() over(order by RequiredDate) num ,* fr ...
- Sql Server 开窗函数Over()的使用
利用over(),将统计信息计算出来,然后直接筛选结果集 declare @t table( ProductID int, ProductName ), ProductType ), Price in ...
- SQL Server开窗函数之OVER子句、PARTITION BY 子句
开窗函数与聚合函数一样,都是对行的集合组进行聚合计算.它用于为行定义一个窗口(这里的窗口是指运算将要操作的行的集合),它对一组值进行操作,不需要使用GROUP BY子句对数据进行分组,能够在同一行中同 ...
- SQL Server 聚合函数算法优化技巧
Sql server聚合函数在实际工作中应对各种需求使用的还是很广泛的,对于聚合函数的优化自然也就成为了一个重点,一个程序优化的好不好直接决定了这个程序的声明周期.Sql server聚合函数对一组值 ...
- SQL Server排序函数row_number和rank的区别
SQL Server排序函数row_number和rank的区别 直接看测试结果 declare @table table(name varchar(100),amount int, memo var ...
- 数据库开发基础-SQl Server 聚合函数、数学函数、字符串函数、时间日期函数
SQL 拥有很多可用于计数和计算的内建函数. 函数的语法 内建 SQL 函数的语法是: SELECT function(列) FROM 表 函数的类型 在 SQL 中,基本的函数类型和种类有若干种.函 ...
随机推荐
- RabbitMQ 汇总
<RabbitMQ Tutorial>译文 第 1 章 简介 <RabbitMQ Tutorial>译文 第 2 章 工作队列 <RabbitMQ Tutorial> ...
- Sleeping会话导致阻塞原理(上)
背景 我在处理客户问题的时候,客户经常搞不懂sleeping 的由来,和他可能导致的问题.下面来详细说下 什么是sleeping 其实我们经常可以在数据库中看到“”sleeping“状态的连接,但是这 ...
- effective c++ 笔记 (13-17)
//---------------------------15/03/30---------------------------- //#13 以对象管理资源 { void f() { Inves ...
- Microsoft Dynamics CRM 增删改子表汇总子表的某个字段到主表的某个字段(通用插件)
背景 经常有某个汇总子表的数量到主表的总数量,或者汇总子表的总价到主表的总价这种需求. 传统的做法: 1.就是为每个子表实体单独写成一个插件,但是这样不好复用. 2.主表的汇总字段是汇总货币类型,但是 ...
- C#图片处理(转zhjzwl/archive)
基本原理: 获取每一个像素值,然后处理这些每一个像素值. 原始图片: ISINBAEVA ~~~~~~~~ 一. 底片效果 原理: GetPixel方法获得每一点像素的值, 然后再使用SetPix ...
- 1分钟,通过docker-compose 搭建zookeeper 集群
一.创建三节点 zookeeper 集群 将 docker-compose.yml 保存到当前命令行目录下 docker-compose.yml 文件 version: '2' networks: z ...
- PHP学习 Object Oriented 面向对象 OO
定义类class class_name [extends partclass_name]{public private protected var property_name = value;publ ...
- PAT甲题题解-1060. Are They Equal (25)-字符串处理(科学计数法)
又是一道字符串处理的题目... 题意:给出两个浮点数,询问它们保留n位小数的科学计数法(0.xxx*10^x)是否相等.根据是和否输出相应答案. 思路:先分别将两个浮点数转换成相应的科学计数法的格式1 ...
- (第十二周)Debug阶段成员贡献分
项目名:食物链教学工具 组名:奋斗吧兄弟 组长:黄兴 组员:李俞寰.杜桥.栾骄阳.王东涵 个人贡献分=基础分+表现分 基础分=5*5*0.5/5=2.5 成员得分如下: 成员 基础分 表现分 个人贡献 ...
- Linux内核分析 实验三:跟踪分析Linux内核的启动过程
贺邦 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 一. 实验过程 ...