Oracle中over函数的使用示例

Oracle中over函数的使用示例

      sum(sal) over (partition by deptno order by ename) 部门连续求和,–各部门的薪水”连续”求和,

  环境:windows 2000 server + Oracle8.1.7 + sql*plus

  目的:以oracle自带的scott模式为测试环境,主要通过试验体会分析函数的用法。

  类似 sum(…) over … 的使用

  1.原表信息:

  SQL> break on deptno skip 1 — 为效果更明显,把不同部门的数据隔段显示。

  SQL> select deptno,ename,sal

  2 from emp

  3 order by deptno;

  DEPTNO ENAME SAL

  ———- ———- ———-

  10 CLARK 2450

  KING 5000

  MILLER 1300

  20 SMITH 800

  ADAMS 1100

  FORD 3000

  SCOTT 3000

  JONES 2975

  30 ALLEN 1600

  BLAKE 2850

  MARTIN 1250

  JAMES 950

  TURNER 1500

  WARD 1250

  已选择14行。

  2.先来一个简单的,注意over(…)条件的不同,

  使用 sum(sal) over (order by ename)… 查询员工的薪水“连续”求和,

  注意over (order by ename)如果没有order by 子句,求和就不是“连续”的,

  放在一起,体会一下不同之处:

  SQL> break on ” — 取消数据分段显示

  SQL> select deptno,ename,sal,

  2 sum(sal) over (order by ename) 连续求和,

  3 sum(sal) over () 总和, — 此处sum(sal) over () 等同于sum(sal)

  4 100*round(sal/sum(sal) over (),4) “份额(%)”

  5 from emp

  6 /

  DEPTNO ENAME SAL 连续求和 总和 份额(%)

  ———- ———- ———- ———- ———- ———-

  20 ADAMS 1100 1100 29025 3.79

  30 ALLEN 1600 2700 29025 5.51

  30 BLAKE 2850 5550 29025 9.82

  10 CLARK 2450 8000 29025 8.44

  20 FORD 3000 11000 29025 10.34

  30 JAMES 950 11950 29025 3.27

  20 JONES 2975 14925 29025 10.25

  10 KING 5000 19925 29025 17.23

  30 MARTIN 1250 21175 29025 4.31

  10 MILLER 1300 22475 29025 4.48

  20 SCOTT 3000 25475 29025 10.34

  20 SMITH 800 26275 29025 2.76

  30 TURNER 1500 27775 29025 5.17

  30 WARD 1250 29025 29025 4.31

  已选择14行。

  3.使用子分区查出各部门薪水连续的总和。注意按部门分区。注意over(…)条件的不同,

  sum(sal) over (partition by deptno order by ename) 按部门“连续”求总和

  sum(sal) over (partition by deptno) 按部门求总和

  sum(sal) over (order by deptno,ename) 不按部门“连续”求总和

  sum(sal) over () 不按部门,求所有员工总和,效果等同于sum(sal)。

  SQL> break on deptno skip 1 — 为效果更明显,把不同部门的数据隔段显示。

  SQL> select deptno,ename,sal,

  2 sum(sal) over (partition by deptno order by ename) 部门连续求和,–各部门的薪水”连续”求和

  3 sum(sal) over (partition by deptno) 部门总和, — 部门统计的总和,同一部门总和不变

  4 100*round(sal/sum(sal) over (partition by deptno),4) “部门份额(%)”,

  5 sum(sal) over (order by deptno,ename) 连续求和, –所有部门的薪水”连续”求和

  6 sum(sal) over () 总和, — 此处sum(sal) over () 等同于sum(sal),所有员工的薪水总和

  7 100*round(sal/sum(sal) over (),4) “总份额(%)”

  8 from emp

  9 /
【编辑推荐】

  1. Oracle认证实用技巧
  2. Oracle数据库开发技术经验浅谈
  3. 一个进入Oracle数据库用户的小诀窍

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/299775.html<

(0)
管理的头像管理
上一篇2025-05-23 13:40
下一篇 2025-05-23 13:41

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注