`

over partition by与group by 的区别

阅读更多
over partition by与group by 的区别

group by 只能得到分组后的统计数据,over partition by 不仅可以得到分组后的统计数据,还可以同时显示明细数据。
group by 是在where子句之后;over partition by 是from子句之前。



各位好!
over partition by 与 group by 都是与统计类函数用,这两个有什么区别呢?
目前我只知道一个这样的区别:
比如有一张表saraly:CREATE TABLE SALARY AS SELECT 'A' NAME,10 DEPT,1000 SALARY FROM DUAL UNION ALL SELECT 'B',10,2000 FROM DUAL UNION ALL SELECT 'C' ,20,1500 FROM DUAL UNION ALL SELECT 'D',20,3000 FROM DUAL UNION ALL
SELECT 'E',10,1000 FROM DUAL;
NAME DEPT SALARY
A         10     1000
B         10     2000
C         20     1500
D         20     3000
E         10     1000  
用over partition by 我就可以查询到每位员工本来的具体信息和它所在部门的总工资:
select name,dept,salary,sum(salary) over (partition by dept) total_salary from salary; 
name       dept         salary      tatal_salary
A        10        1000        4000
B        10        2000        4000
E        10        1000        4000
C        20        1500        4500
D        20        3000        4500

用goup by 就没办法做到这点,只能查询到每个部门的总工资:
select dept,sum(salary) total_salary from salary group by dept
dept        total_salary
10        4000
20        4500
另外over partion by 还可以做到查询每位员工占部门总工资的百分比:
select name,dept,salary,salary*100/sum(salary) over (partition by dept) percent from salary;

name       dept         salary     percent
A        10        1000        25
B        10        2000        50
E        10        1000        25
C        20        1500        33.3333333333333
D        20        3000        66.6666666666667
用group by 也没办法做到这个.不知道我的理解正不正确,请各位朋友指点,特别是over partition by 与group by 的更多区别请各位一起分享,谢谢!
分享到:
评论

相关推荐

    详解partition by和group by对比

    在实际应用中,理解 `GROUP BY` 和 `PARTITION BY` 的区别以及它们各自的用途非常重要,这有助于编写出更高效、更灵活的 SQL 查询,满足各种复杂的数据处理需求。对于数据库性能优化,合理使用这两种方法也能有效...

    SQLServer中Partition By及row_number 函数使用详解

    这与`GROUP BY` 有所不同,`GROUP BY` 主要是用于对数据进行聚合,通常与聚合函数(如 `SUM`, `COUNT`, `AVG` 等)结合使用,而返回的结果集中每组只有一条记录。而 `PARTITION BY` 可以在每个分组内部返回多条记录...

    只满足某个条件的查询效率分析

    介绍了 1.NOT EXISTS, 2.GROUP BY ... [HAVING ...] 3.count(*) over(partition by ...) 做查询的效率,以及各自的使用方法

    Group BY 的另一种写法

    这里的`OVER(PARTITION BY column1)`部分相当于`GROUP BY column1`,而`ORDER BY some_column`则确定了在每个组内如何选择记录。 在大数据量处理时,优化`GROUP BY`语句的写法至关重要,因为它直接影响到查询的效率...

    ch08_ 秋招秘籍 C1

    CASE WHEN DATE_SUB(imp_date, INTERVAL 1 DAY) = LAG(imp_date, 1) OVER (PARTITION BY uid ORDER BY imp_date) THEN LAG(consecutive_group, 1) OVER (PARTITION BY uid ORDER BY imp_date) ELSE NULL END AS ...

    oracle分组排序统计高级用法

    其中`GROUP BY`、`ORDER BY`、`OVER`子句以及`ROW_NUMBER()`、`RANK()`、`DENSE_RANK()`等分析函数都是非常有用的工具。在实际应用中,根据具体的需求选择合适的工具和技术组合可以大大提高数据处理的效率和灵活性。...

    My SQL group by取同组第一条

    ROW_NUMBER() OVER(PARTITION BY MemberID ORDER BY AddTime ASC) as row_num FROM front_membercardswipe fmcs ) t WHERE t.row_num = 1; ``` 这里,我们使用窗口函数 `ROW_NUMBER()` 来为每个`MemberID`分组...

    ORACLE分析函数.pdf

    SUM(LOCAL_FARE) OVER (PARTITION BY NET_TYPE ORDER BY BILL_MONTH ROWS BETWEEN 2 PRECEDING AND CURRENT ROW) as MOVING_SUM, AVG(LOCAL_FARE) OVER (PARTITION BY NET_TYPE ORDER BY BILL_MONTH ROWS BETWEEN ...

    oracle分析函数.doc

    这里,`COUNT(*) OVER (PARTITION BY corp ORDER BY year)`会根据年份递增的方式累计每个公司每年的电影数量。 ##### 4.3 RANK, DENSE_RANK, ROW_NUMBER 这三个函数用于对结果集中的行进行排序并赋予一个唯一的...

    oracle分析函数的使用

    1. 传统的统计函数,如`COUNT()`,通常与`GROUP BY`一起使用来计算每个类别的数量。例如,我们可以计算每个班级的学生数量: ```sql SELECT t.class, COUNT(*) FROM t_student_score t GROUP BY t.class; ``` 如果...

    分析函数,数据库开发

    RATIO_TO_REPORT(column_name) OVER (PARTITION BY partition_column ORDER BY order_column) ``` ##### 示例 假设有一个销售数据表,我们想计算每个产品的销售额在其所在类别的总销售额中的比例。 ```sql SELECT ...

    hive窗口函数

    SUM(pv) OVER (PARTITION BY cookieid ORDER BY createtime ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS pv2, SUM(pv) OVER (PARTITION BY cookieid) AS pv3, SUM(pv) OVER (PARTITION BY cookieid ...

    SQL中row-number函数用法

    ROW_NUMBER() OVER ( [PARTITION BY partition_expression, ...] ORDER BY order_by_expression [ASC | DESC], ... ) ``` - **PARTITION BY**:可选参数,用于指定分组字段。当指定了这个参数时,`row_number()` 将...

    Gbase 8s内置函数之窗口函数

    ROW_NUMBER() OVER (PARTITION BY f_deptid ORDER BY f_salary DESC) AS f_order, f_deptname, f_employeename, f_salary FROM (SELECT a.f_employeeid, a.f_deptid, b.f_deptname, a.f_...

    Oracle 分析函数

    `OVER`子句定义了分析函数的行为,其中`PARTITION BY department_id`表示按部门分组,而`ORDER BY salary DESC`则是指在每个部门内按照薪资降序排列。 #### 三、分析函数OVER解析 - **1. 分析函数的基本结构** `...

    oracle函数介绍(5) 分析函数简述.doc

    第五篇 分析函数简述 分析函数的语法结构比较复杂,但多数函数都具有相同的语法...Partition没啥说的,功能强大参数少,主要用于分组,可以理解成select中的group by。不过它跟select语句后跟的group by 子句并不冲突。

    ETL开发常用语句案例分享.docx

    MAX(CLOSEPRICE) OVER(PARTITION BY SYMBOL ORDER BY TRADINGDATE ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) AS MAXT FROM ZZ_IDX_MKT_QUOTATION a 这条语句计算每个 SYMBOL 分组的 ...

    有幸去华为面试数据分析岗,看到SQL后我拒绝了.docx

    在这个示例中,`OVER(PARTITION BY name)`确保了每个学生内部的排名,而`ORDER BY SUM(score) DESC`则根据总分降序排列。 总之,SQL能力的熟练掌握对于数据分析岗位至关重要,无论是数据提取、聚合,还是复杂的数据...

Global site tag (gtag.js) - Google Analytics