- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
over分析函數
准备工作: table:oracle用户scott下的emp表 ; 一. Oracle 从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是 对于每个组返回多行,而聚合函数对于每个组只返回一行。 exp:
Sql代码
select?t.empno,t.ename,sum(t.sal)?from?emp?t??
这样会报:ORA-00937:非单组分组函数; 结论:聚合函数只能返回1行值。
Sql代码
select?t.empno,t.ename,sum(t.sal)over()?sum?from?emp?t??
返回的结果:
empno ename sum 7369 SMITH 142781.99 7499 ALLEN 142781.99 7521 WARD 142781.99 7566 JONES 142781.99 7654 MARTIN 142781.99 7698 BLAKE 142781.99 7782 CLARK 142781.99 7788 SCOTT 142781.99 7839 KING 142781.99 7844 TURNER 142781.99 7876 ADAMS 142781.99 7900 JAMES 142781.99 7902 FORD 142781.99 7934 MILLER 142781.99 结论:这就是每个组返回多行。 二. over()、over(order by...)与over(partition by...)之间的区别 1.分析函数over()用在聚合函数(max(),sun()....)后面,可返回多行所有结果的聚合值; exp:如上; 2.over(order by...)用在聚合函数(max(),sun()....)后面,可返回根据排序结果进行统计到当前行的聚合值(即“连续”统计); exp:
Sql代码
select?t.empno,??
???????t.deptno,??
???????t.ename,??
???????t.sal,??
???????sum(t.sal)?over(order?by?t.ename)?sum??
??from?emp?t??
返回的结果:
empno deptno ename?? ? sal?? ??? sum 7876 20 ADAMS 4646.11 4646.11 7499 30 ALLEN 8493.66 13139.77 7698 30 BLAKE 15047.69 28187.46 7782 10 CLARK 11823.85 40011.31 7902 20 FORD 14935.97 54947.28 7900 30 JAMES 4935.36 59882.64 7566 20 JONES 15086.30 74968.94 7839 10 KING 23841.13 98810.07 7654 30 MARTIN 6526.80 105336.87 7934 10 MILLER 6167.32 111504.19 7788 20 SCOTT 12710.16 124214.35 7369 20 SMITH 4089.17 128303.52 7844 30 TURNER 7843.77 136147.29 7521 30 WARD 6634.70 142781.99 分析:第二行的sum=第一行里的sal+第二行里的sal; ????? 第二行的sum=第一行里的sal+第二行里的sal+第三行里的sal; ????? ..... 结论:返回值是根据排序后的结果,当前所在的行进行统计的。 3.over(partition by...)用在聚合函数(max(),sun()....)后面,可根据pratition by里指定的某一列来统计聚合值。 exp:
Sql代码
select?t.empno,??
???????t.deptno,??
???????t.ename,??
???????t.sal,??
???????sum(t.sal)?over(partition?by?t.deptno)?sum??
??from?emp?t??
返回的结果:
empno deptno?? ename?? ? sal?? ??? sum 7782 10 CLARK 11823.85 41832.3 7839 10 KING 23841.13 41832.3 7934 10 MILLER 6167
您可能关注的文档
- oracle死鎖及处理方式.docx
- oracle的安裝.doc
- Oracle系列培訓教程之七数据库性能优化.doc
- Oracle系列培訓教程之五逻辑结构.doc
- Oracle簡易培训教程.doc
- oracle與mysql差异对比v1.0.doc
- Oracle與提高性能有关的特性.doc
- Oracle集合類型输出参数的PLSQL存储过程及其Java调用.doc
- oracle面試题大全.doc
- OregonScientific營销策划方案V-2.0.doc
- 2026秋季中国工商银行集约运营中心(佛山)校园招聘20人备考题库含答案详解(培优).docx
- 中国农业银行宁波市分行2026年度校园招聘214人备考题库附答案详解(夺分金卷).docx
- “梦工场”招商银行长沙分行2026寒假实习生招聘备考题库附答案详解(轻巧夺冠).docx
- 2026贵州省公共资源交易中心定向部分高校选调优秀毕业生专业技术职位考试备考题库完整参考答案详解.docx
- 中国建设银行建信金融资产投资有限公司2026年度校园招聘8人备考题库含答案详解(a卷).docx
- 中国农业银行宁夏回族自治区分行2026年度校园招聘146人备考题库及一套参考答案详解.docx
- 门头沟区青少年事务社工招聘1人备考题库附答案详解(模拟题).docx
- 中国建设银行运营数据中心2026年度校园招聘20人备考题库含答案详解ab卷.docx
- 中国建设银行建银工程咨询有限责任公司2026年度校园招聘9人备考题库及答案详解(有一套).docx
- 2026秋季中国工商银行重庆市分行校园招聘270人备考题库含答案详解(完整版).docx
最近下载
- 弱电机房数据中心的选址及现场勘察表格.docx VIP
- 分子生物学智慧树知到课后章节答案2023年下温州医科大学.docx VIP
- 17J008 挡土墙(重力式、衡重式、悬臂式)(最新).pdf VIP
- 基恩士PLC编程手册.pdf VIP
- 电网侧独立储能电站项目经济效益和社会效益分析报告.docx
- 2025年6月福建省普通高中学生学业基础会考历史试卷(含答案) .pdf VIP
- 上汽荣威2017款Ei6 维修手册03-2发动机机械系统-1.0T.pdf
- GB_T 43439-2023 信息技术服务 数字化转型 成熟度模型与评估.pdf VIP
- (新课标)三年级上册第六单元测试A卷(含答案).pdf VIP
- 烟草专卖局培训课件:打击互联网涉烟违法犯罪.ppt
原创力文档


文档评论(0)