首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Oracle中的OVER子句

Oracle中的OVER子句
EN

Stack Overflow用户
提问于 2009-07-07 12:47:18
回答 3查看 156.5K关注 0票数 78

Oracle中OVER子句的含义是什么?

EN

回答 3

Stack Overflow用户

发布于 2009-07-07 12:50:17

您可以使用它将一些聚合函数转换为分析函数:

代码语言:javascript
复制
SELECT  MAX(date)
FROM    mytable

将返回具有单个最大值的1行,

代码语言:javascript
复制
SELECT  MAX(date) OVER (ORDER BY id)
FROM    mytable

将返回具有运行最大值的所有行。

票数 32
EN

Stack Overflow用户

发布于 2009-07-07 12:48:16

它是Oracle analytic functions的一部分。

票数 20
EN

Stack Overflow用户

发布于 2021-02-12 21:55:01

使用OVER的另一种方式是让select中的结果列对另一个“分区”进行操作。

这一点:

代码语言:javascript
复制
SELECT 
    name, 
    ssn, 
    case 
      when ( count(*) over (partition by ssn) ) > 1      
      then 1
      else 0
    end AS hasDuplicateSsn
FROM table;

对于其ssn由另一行共享的每一行,在hasDuplicateSsn中返回1。非常适合为不同错误报告的数据做“标签”。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1092120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档