Oracle over窗口函数

oracle over函数

select t1.*, (t1.score - t3.avgs) as gaps
  from test_student_score t1,
       (select t2.subject_id, avg(t2.score) as avgs
          from test_student_score t2
         group by t2.subject_id) t3
 where t1.subject_id = t3.subject_id;

如果是使用over 窗口函数,这个sql就变成了一行代码,如下

select t.*,
       (t.score-avg(t.score) over( partition by t.subject_id)) as gaps 
   from test_student_score t

删除重复记录sql

-- sql是对的,但是执行计划有问题
delete test where rowid not in (select max(rowid) from test group by object_id)

delete test where rowid in(
    select row_number() over(partition by object_id order by )
)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
引用提到了Oracle中的窗口函数窗口函数是一种用于查询和计算的特殊函数。它可以和其他函数(如统计函数、排名函数、错行函数)联合使用,能够在一次查询中进行多步计算。窗口函数的常用属性是partition by和order by,其中partition by类似于group by,用于将结果分成不同的分区,而order by用于指定排序的顺序。 引用给出了一个使用窗口函数的例子,查询每个同学单科成绩和班级相应单科成绩的差值。使用窗口函数可以简化这个查询,代码如下: ```sql select t.*, (t.score-avg(t.score) over( partition by t.subject_id)) as gaps from test_student_score t ``` 这个查询使用了over函数和partition by子句来计算每个同学单科成绩和班级相应单科成绩的差值。 引用中展示了另一个常用的窗口函数示例,用于去重。这个查询使用了row_number()函数配合over函数和partition by子句来对数据进行编号,并筛选出每个分组中的第一行数据。 总结来说,Oracle中的窗口函数是一种强大的工具,可以简化复杂的查询和计算,常用的属性有partition by和order by。它可以和其他函数联合使用,可以满足各种数据分析和计算的需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Oracle中的窗口函数](https://blog.csdn.net/wyqwilliam/article/details/82555712)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [oracle的分组排序函数(窗口函数)](https://blog.csdn.net/m0_46636892/article/details/122984409)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄宝康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值