位置: 编程技术 - 正文

开窗函数有浅入深详解(一)(开窗函数窗口范围)

编辑:rootadmin

推荐整理分享开窗函数有浅入深详解(一)(开窗函数窗口范围),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:开窗函数的区别,开窗函数窗口范围,开窗函数 sum,开窗函数的区别,开窗函数用法,开窗函数 lag,开窗函数的区别,开窗函数的区别,内容如对您有帮助,希望把文章链接给更多的朋友!

在开窗函数出现之前存在着很多用 SQL 语句很难解决的问题,很多都要通过复杂的相关子查询或者存储过程来完成。为了解决这些问题,在年ISO SQL标准加入了开窗函数,开窗函数的使用使得这些经典的难题可以被轻松的解决。

目前在 MSSQLServer、Oracle、DB2 等主流数据库中都提供了对开窗函数的支持,不过非常遗憾的是 MYSQL 暂时还未对开窗函数给予支持。

为了更加清楚地理解,我们来建表并进行相关的查询(截图为MSSQLServer中的结果)

MYSQL,MSSQLServer,DB2:

Oracle:

注:以下结果只在MSSQLServer中演示:

T_Person 表保存了人员信息,FName 字段为人员姓名,FCity 字段为人员所在的城市名,FAge 字段为人员年龄,FSalary 字段为人员工资。

然后执行下面的SQL语句向 T_Person表中插入一些演示数据:

查看表中的内容:

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_ada.png" alt="查看图片" />

开窗函数简介

与 聚 合函数一样,开窗函数也是对行集组进行聚合计算,但是它不像普通聚合函数那样每组只返回一个值,开窗函数可以为每组返回多个值,因为开窗函数所执行聚合计算的行集组是窗口。

在ISO SQL规定了这样的函数为开窗函数,在 Oracle中则被称为分析函数,而在DB2中则被称为OLAP函数。

要计算所有人员的总数,我们可以执行下面的 SQL语句:

除了这种较简单的使用方式,有时需要从不在聚合函数中的行中访问这些聚合计算的值。比如我们想查询每个工资小于 元的员工信息(城市以及年龄) ,并且在每行中都显示所有工资小于元的员工个数,尝试编写下面的 SQL语句:

开窗函数有浅入深详解(一)(开窗函数窗口范围)

执行上面的SQL以后我们会得到下面的错误信息:

选择列表中的列 'T_Person.FCity' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。

这是因为所有不包含在聚合函数中的列必须声明在GROUP BY 子句中,可以进行如下修改:

执行完毕我们就能在输出结果中看到下面的执行结果:

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_a.png" alt="查看图片" />

这个执行结果与我们想像的是完全不同的,这是因为GROUP BY子句对结果集进行了分组,所以聚合函数进行计算的对象不再是所有的结果集,而是每一个分组。

可以通过子查询来解决这个问题,SQL如下:

执行完毕我们就能在输出结果中看到下面的执行结果:

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_aabdc9.png" alt="查看图片" />

虽然使用子查询能够解决这个问题,但是子查询的使用非常麻烦,使用开窗函数则可以大大简化实现,下面的SQL语句展示了如果使用开窗函数来实现同样的效果:

执行完毕我们就能在输出结果中看到下面的执行结果:

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_ab.png" alt="查看图片" />

可以看到与聚合函数不同的是,开窗函数在聚合函数后增加了一个OVER 关键字。

开窗函数的调用格式为:

函数名(列) OVER(选项)

OVER 关键字表示把函数当成开窗函数而不是聚合函数。SQL 标准允许将所有聚合函数用做开窗函数,使用OVER 关键字来区分这两种用法。

在上边的例子中,开窗函数COUNT(*) OVER()对于查询结果的每一行都返回所有符合条件的行的条数。OVER关键字后的括号中还经常添加选项用以改变进行聚合运算的窗口范围。

如果OVER关键字后的括号中的选项为空,则开窗函数会对结果集中的所有行进行聚合运算。

总结:上述讲述的是开窗函数的基本用法,希望对大家有所帮助!

记一次公司仓库数据库服务器死锁过程及解决办法 死锁的四个必要条件:互斥条件(Mutualexclusion):资源不能被共享,只能由一个进程使用。请求与保持条件(Holdandwait):已经得到资源的进程可以再次申请

实用的银行转账存储过程和流水号生成存储过程 银行转账存储过程USE[BankInfor]GOSETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOALTERPROCEDURE[dbo].[Transfer](@inAccountint,@outAccountint,@amountfloat)asdeclare@totalDepositfloat;beginselect@totalD

asp.net中如何调用sql存储过程实现分页 首先看下面的代码创建存储过程1、创建存储过程,语句如下:CREATEPROCP_viewPage@TableNameVARCHAR(),--表名@FieldListVARCHAR(),--显示列名,如果是全部字段则

标签: 开窗函数窗口范围

本文链接地址:https://www.jiuchutong.com/biancheng/347379.html 转载请保留说明!

上一篇:SQLserver排序规则基本概念探索(sqlserver排序规则怎么看)

下一篇:记一次公司仓库数据库服务器死锁过程及解决办法(仓库记录)

  • 银行委托贷款上征信吗
  • 什么是企业的应纳税额
  • 哪些税不用通过应交税费
  • 建筑业小规模纳税人 扣除分包款 开票
  • 上市公司股价变动谁受益
  • 会计凭证借方和贷方怎么填
  • 结转税金为贷方怎么结转?
  • 自用房产税如何计算
  • 纳税申报表如何导出
  • 房屋维修基金怎么入帐
  • 按计划成本发出原材料怎么算
  • 应付债券利息调整科目理解
  • 营改增后房地产企业增值税如何核算
  • 六月涉税提醒通知
  • 个人收到支票如何做账
  • 银行呆帐坏账
  • 一年期电子银行承兑汇票
  • 不占股权投资如何做账
  • 出口报关单中有哪些内容
  • win10取消登陆密码
  • 现金流量表的编制方法
  • 赡养人 被赡养人
  • 支付的测试流程
  • php数组函数有哪些
  • php响应时间
  • 利用php计算1+2+3+...+100
  • 技术转市场到底是不是个正确的选择
  • 社保比例调整后多久生效
  • 借银行存款贷预收账款
  • 盘亏前累计折旧怎么算
  • node .js
  • Vue3入门笔记----登录功能
  • 代理业务怎么记账
  • python科学计算库有哪些
  • 借支差旅费属于什么科目
  • 水利基金应税项填的数据怎么查
  • sql优化方式
  • 建立access数据库一般需要五个步骤
  • 仓库物资盘盈盘亏怎么办
  • 兼职老师工资小时多少钱
  • 多交个税收到退回怎么办
  • 施工审图费计入什么科目
  • 未使用的固定资产计提折旧计入什么科目
  • 个税 退手续费
  • 企业未按照规定报送年度报告怎么办
  • 被收购企业账务处理流程
  • 哪些计入研发费用
  • 工程预缴税款流程
  • 票据到期无力支付怎么办
  • 纳税人购进国内商品
  • 债务现金流量是正还是负
  • 明年发票可以入到今年有什么惩罚
  • 预收账款是什么资产
  • windows vista home basic
  • windows2003怎么样
  • centosip配置
  • 电脑主板bios设置图解
  • ktpcntr.exe
  • linux系统怎么安装
  • 虚拟网卡在哪里设置
  • linux系统中make的用法
  • js中onunload
  • 2014年最火的英文歌
  • 本科生面试的自我介绍
  • jQuery扩展实现text提示还能输入多少字节的方法
  • 编写批处理运行程序
  • 传智播客javappt
  • 在javascript中
  • js日期格式化方法
  • python快捷键大全
  • js获取
  • Sublime Text 3常用插件及安装方法
  • jquery插件是干什么的
  • python中fun函数怎么用
  • 支付境外公司服务费需要缴纳哪些税费
  • 网上如何申领电瓶车牌照
  • 上海自贸试验区临港新片区
  • 浅谈新时代劳动教育答案
  • 单位医保账号怎么注销掉
  • 抄税失败是怎么回事
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设