Oracle 中带和不带 KEEP 的 PARTITION BY
Oracle 中的 PARTITION BY 子句允许用户根据指定的列对表中的行进行分组用于汇总计算。在某些情况下,KEEP 子句可以与 PARTITION BY 结合使用来控制每个分区中各个行的保留。
KEEP 的语法:
MIN(sal) KEEP (DENSE_RANK FIRST ORDER BY sal) OVER (PARTITION BY deptno)
在此语法中,KEEP 子句后面是 DENSE_RANK FIRST,表示工资最低的行应保留在每个 分割。 DENSE_RANK 确保连续排名,这意味着具有相同薪水的行将具有相同的排名。
不带 KEEP 的语法:
MIN(sal) OVER (PARTITION BY deptno)
在此语法中,省略了 KEEP 子句。如果没有 KEEP,则聚合计算时会考虑每个分区中的所有行,这可能会导致结果中包含具有相同值的多行。
差异:
两个查询的主要区别在于:
冗余KEEP:
在提供的例如,KEEP 子句是多余的,因为 MIN 函数也应用于同一列 (sal)。因此,根据工资排名第一的行始终是工资最低的行。
具有不同排序列的示例:
但是,如果不同排序列用于 KEEP 子句,它可以产生不同的效果:
MIN(sal) KEEP (DENSE_RANK FIRST ORDER BY name) OVER (PARTITION BY deptno)
在这种情况下,带有每个分区中将保留具有相同顺序(姓名)的最低工资。这允许用户为每个部门内具有特定姓名的员工选择最低工资。
以上是Oracle 中的'KEEP”子句如何影响'PARTITION BY”聚合函数?的详细内容。更多信息请关注PHP中文网其他相关文章!