开窗函数 函数() OVER()
-- 初始化
CREATE TABLE T_Person
(FName VARCHAR2(20), FCity VARCHAR2(20), FAge INT, FSalary INT);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Tom','BeiJing',20,3000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Tim','ChengDu',21,4000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Jim','BeiJing',22,3500);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Lily','London',21,2000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('John','NewYork',22,1000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('YaoMing','BeiJing',20,3000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Swing','London',22,2000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Guo','NewYork',20,2800);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('YuQian','BeiJing',24,8000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Ketty','London',25,8500);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Kitty','ChengDu',25,3000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Merry','BeiJing',23,3500);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Smith','ChengDu',30,3000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Bill','BeiJing',25,2000);
INSERT INTO T_Person(FName, FCity, FAge, FSalary) VALUES('Jerry','NewYork',24,3300); 开窗函数与聚合函数一样,也是对行集组进行聚合计算,但是不像普通聚合函数那样每组只返回一个值,开窗函数可以为每组返回多个值,因为开窗函数所执行
计算的行集组是窗口
SELECT COUNT(*) FROM T_Person;
-- 查询每个工资小于5000元的员工信息,并且在每行中都显示所有工资小于5000元的员工个数,报错:列名无效,不包含在聚合函数或者GROUP BY子句中
SELECT FCity, FAge, COUNT(*) FROM T_Person WHERE FSalary <5000;
-- 修改后得到的COUNT(*)不是我想要的
SELECT FCity, FAge,COUNT(*) FROM T_Person WHERE FSalary <5000 GROUP BY FCity,FAge;
-- 通过子查询来解决这个问题
SELECT FCity, FAge, (SELECT COUNT(*) FROM T_Person WHERE FSalary < 5000) FROM T_Person WHERE FSalary <5000;
-- 使用开窗函数
SELECT FCity, FAge, COUNT(*) OVER() FROM T_Person WHERE FSalary <5000;
与聚合函数不同的是,开窗函数在聚合函数后增加了一个OVER关键字。开窗函数的调用格式为:函数名(列) OVER(选项),over关键字把函数当成开窗函数而不是
聚合函数,SQL标准允许将所有聚合函数用做开窗函数,使用OVER关键字来区分这两种用法。OVER()对于查询结果的每一行都返回所有符合条件的行的条数,OVER
关键字后的括号中还经常添加选项,用以改变对聚合运算的窗口范围 开窗函数的OVER关键字后的括号中,可以使用PARTITION BY子句来定义行的分区,从而进行聚合计算。与GROUP BY不同,PARTITION BY子句创建的分区是独立于结
果集的,创建的分区只是供进行聚合运算的,而且不同的开窗函数所创建的分区也互不影响 -- COUNT(*) OVER (PARTITION BY FCity) 表示对结果集按照FCity进行分区,并且计算当期行所属的组的聚合计算结果,多个开窗函数不会互相干扰
SELECT FName, FCity, FAge, FSalary, COUNT(*) OVER (PARTITION BY FCity) FROM T_Person;
SELECT FName, FCity, FAge, FSalary, COUNT(*) OVER (PARTITION BY FCity), COUNT(*) OVER(PARTITION BY FAge) FROM T_Person; 开窗函数可以在OVER关键字后的选项中使用ORDER BY子句来指定排序规则,而且有的开窗函数还要求必须指定排序规则。使用 ORDER BY 子句可以对结果集按照
指定的排序规则进行排序,并且在一个指定的范围内进行聚合运算。 ORDER BY 子句的语法为: ORDER BY 字段名 RANGE|ROWS BETWEEN 边界规则1 AND 边界规
则2
RANGE 按照值得范围进行范围的定义,而ROWS表示按照行的范围进行范围的定义,边界规则得取值表:
CURRENT ROW : 当前行
N PRECEDING :前N行
UNBOUNDED PRECEDING : 一直到第一条记录
N FOLLOWING :后N行
UNBOUNDED FOLLOWING : 一直到最后一条记录
RANGE|ROWS BETWEEN 边界规则1 AND 边界规则2 用来定位聚合计算范围 -- 表示按照FSalary进行排序,然后计算从第一行到当前行的和,这样的额计算结果就是按照工资进行排序的工资值得累积和
SELECT FName, FSalary, SUM(FSalary) OVER(ORDER BY FSalary ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) FROM T_Person
-- 表示按照FSalary进行排序,然后计算从第一行到当前行工资范围内的和
SELECT FName, FSalary, SUM(FSalary) OVER(ORDER BY FSalary RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) FROM T_Person
-- 表示按照FSalary进行排序,然后计算从当前行前两行到当前行后2行的工资和
SELECT FName, FSalary, SUM(FSalary) OVER(ORDER BY FSalary ROWS BETWEEN 2 PRECEDING AND 2 FOLLOWING) FROM T_Person
-- 表示按照FSalary进行排序,然后计算从当前行后1行到当前行后3行的工资和
SELECT FName, FSalary, SUM(FSalary) OVER(ORDER BY FSalary ROWS BETWEEN 1 FOLLOWING AND 3 FOLLOWING) FROM T_Person
-- 使用行号为范围,第一行到当前行是默认的定位框架,可以省略
SELECT FName, FSalary, FAge, MAX(FSalary) OVER(PARTITION BY FAge ORDER BY FSalary ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) FROM T_Pers
on
SELECT FName, FSalary, FAge, MAX(FSalary) OVER(PARTITION BY FAge ORDER BY FSalary) FROM T_Person 除了在聚合函数使用开窗函数之外,一些高级函数也可以。如:RANK()、 DENSE_RANK()、 ROW_NUMBER()等
开窗函数 函数() OVER()的更多相关文章
- 不可或缺 Windows Native (16) - C++: 函数重载, 缺省参数, 内联函数, 函数模板
[源码下载] 不可或缺 Windows Native (16) - C++: 函数重载, 缺省参数, 内联函数, 函数模板 作者:webabcd 介绍不可或缺 Windows Native 之 C++ ...
- Swift 学习一函数&函数属性&懒加载
函数 函数相当于OC中的方法 格式: func 函数名(参数列表) -> 返回值类型 { 代码块 return 返回值} func 函数名(参数列表){ // 返回值为Void 可 ...
- 我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中:
我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中: C/C++ code ? 1 int retrieve(int scanno,void* buf); 在 ...
- Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数
Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数 目录 Pycharm使用技巧(转载) Python第一天 ...
- python基础 (初识函数&函数进阶)
函数基础部分 .什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...
- 函数函数sigaction、signal
函数函数sigaction 1. 函数sigaction原型: int sigaction(int signum, const struct sigaction *act, struct sigact ...
- python基础之 初识函数&函数进阶
函数基础部分 1.什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...
- day20 Python 高阶函数,函数,嵌套,闭包 装饰器
高阶函数定义 1.函数接收的参数是一个函数名 2.函数的返回值是一个函数名 3.满足上述条件任意一个都可以称之为高阶函数 一.函数的接收参数是一个函数名 import time def foo(): ...
- JavaScript 引入方式 语言规范 语言基础 数据类型 常用方法 数组 if_else 比较运算符 for while 函数 函数的全局变量和局部变量 {Javascript学习}
Javascript学习 JavaScript概述 ECMAScript和JavaScript的关系 1996年11月,JavaScript的创造者--Netscape公司,决定将JavaScript ...
- python -- 初始函数 函数的定义,函数的返回值以及函数的参数
1.什么是函数,函数的定义及语法 2.函数的返回值 3.函数的参数 一.函数的定义及语法 函数的定义:定义了一个动作或者功能,是对功能的封装 语法: def 函数名( 形参列表 ): ...
随机推荐
- AngularJS参数绑定 --AngularJS
AngularJS参数绑定有三种方式.第一种插值表达式“{{}}”表示,第二种在标签中使用ng-bind属性表示,第三种针对input框(标签)的ng-module属性表示.针对三种参数绑定方式,设定 ...
- 【消息队列】kafka是如何保证消息不被重复消费的
一.kafka自带的消费机制 kafka有个offset的概念,当每个消息被写进去后,都有一个offset,代表他的序号,然后consumer消费该数据之后,隔一段时间,会把自己消费过的消息的offs ...
- LeetCode--682--棒球比赛(java)
你现在是棒球比赛记录员. 给定一个字符串列表,每个字符串可以是以下四种类型之一:1.整数(一轮的得分):直接表示您在本轮中获得的积分数.2. "+"(一轮的得分):表示本轮获得的得 ...
- vue核心之虚拟DOM
一.前言 虚拟DOM概念随着react的诞生而诞生,由facebook提出,其卓越的性能很快得到广大开发者的认可:继react之后vue2.0也在其核心引入了虚拟DOM的概念,本文将以vue2.0使用 ...
- python基础之生成器,生成器函数,列表推导式
内容梗概: 1. 生成器和生成器函数. 2. 列表推导式. 1.生成器函数1.1 生成器函数. 就是把return换成yield def gen(): print("爽歪歪") y ...
- DP 租用游艇
洛谷P1359租用游艇 分析:这个游艇我看到题目下意识的就想将dp数组设为dp[i][j]表示i到j之间的最短距离,但题目上要求的只是从起点到终点的距离,这样设只是自找麻烦. 直接设成dp[i]表示从 ...
- zend framwork黑箱测试
1.我采用的测试时phpunit 1).按照:https://phpunit.de/ 把下载的文件放到C:/window 目录,让后修改一下文件的后缀,使在敲击命令的时候可以不用敲文件的全称 如:p ...
- 9. Palindrome Number(回文数)C++
将int转换为string,注意for循环判断条件的简化 class Solution { public: bool isPalindrome(int x) { ) return false; str ...
- .NET面试基本问题
1..NET和C#的区别? .NET:一般指的是.NET FrameWork框架,是平台,技术. C#:是一编程语言,是基本.NET平台. 2.C#的委托是什么?事件是不是委托? 委托可以把一个方法作 ...
- 十三、MVC的WEB框架(Structs2)
一.Structs2的应用 Structs2是基于MVC的WEB框架.一般基于框架的程序要运行成功,对于JAR包的版本,配置文件的正确性有着苛刻的要求,一个地方错了,都会导致框架程序运行出错. 1.首 ...