oracle多条件分组查询数量_ORACLE分组查询和统计等

select flow_id,rw from (select t.flow_id ,rownum as rw from apex_030200.wwv_flow_list_templates t)  where rw >= 5

1.rownum只能用加别名

2.子查询引用只能在查询出的结果中引用,比如子查询没有查出flow_id,外层不能用,另外外层不能引用内层的t

3.薪水前三名,内层查出薪水 order desc的虚表外层使用rownum<3

4.merge可以实现存在数据就update不存在你就insert

merge into product a

using (select  1717 product_id, '002' req_no from dual b)

on (a.product_id = b.product.id and a.req_no = b.req.no)

when matched then

update set  product name = ''.....................

when not matched then

insert () values ()

5.start with connect by 可以查询出一组树的数据,注意最后connect by的条件(父节点=子节点 向上查询 反之向下查询)

可以order排序,可以加入两棵树(or),也可以加入where条件

select * from emp

where......

start with empnc = 7369 or empnc = 7204(注意不能用and )

connect by prior mgr = empno

order by ...

6 份额(查询某数据占有总数据的百分比)

select t.empno,t.ename,t.sal,

100*round(sal/sum(sal) over(),5)

from emp t

7 连续求和(同名分为同组 累加)

select t.empno,t.ename,t.sal,

sum(sal) over(order by sal)

from emp t

8.带条件的连续求和(分部门连续求和)

select t.empno,t.ename,t.sal,t.deptno,

sum(sal) over(partition by t.deptno order by sal)

from emp t

9.分部门总和(取出orderby)

select t.empno,t.ename,t.sal,t.deptno,

sum(sal) over(partition by t.deptno)

from emp t

10工资的分组查询份额(总数的百分比)带上部门分组

select t.empno,t.ename,t.sal,t.deptno,

100*round(sal/sum(sal) over (partition by t.deptno),4)

from emp t

注意这里查询的是“”分

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值