oracle怎么算占比,oracle 比例

如何在oracle里面实现占比统计的问题

where num=a

创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:做网站、成都网站设计、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的杭州网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

这些数据可以直接算的

count(decode(num,a,你要加的字段,null))

oracle中如何求百分比?

实现代码:

ELECT(CASE WHEN db_psndoc.age=30 THEN '30岁以上'

WHEN db_psndoc.age30 THEN '30岁及以下' END)

ranges, COUNT(*) rs ,100*round(COUNT(*)/SUM(COUNT(*))

OVER(),4)||'%' percent FROM bd_psnd

GROUP BY CASE

WHEN bd_psndoc.age=30 then '30岁及以下'

WHEN db_psndoc.age=30 THEN '30岁以上'

END

扩展资料

sum(..) over(..)用法分析:

sum(…) over( ),对所有行求和;

sum(…) over( order by … ), 连续求和;

sum(…) over( partition by… ),同组内所行求和;

sum(…) over( partition by… order by … ),同第1点中的排序求和原理,只是范围限制在组内。

over不能单独使用,要和分析函数:rank(),dense_rank(),row_number(),sum()等一起使用。

over函数的参数:over(partition by columnname1 order by columnname2)

含义,按columname1指定的字段进行分组排序,或者说按字段columnname1的值进行分组排序。

例子:

select deptno,ename,sal,

sum(sal) over (partition by deptno order by ename) 部门连续求和,--各部门的薪水"连续"求和

sum(sal) over (partition by deptno) 部门总和, -- 部门统计的总和,同一部门总和不变

oracle 合计行占比如何计算?

提一个不太好的办法,计算的时候可以用case when分支将合计行提出来单独计算。

比如case when md5_at=男 and md7_at like '%合计' then dh_c_stylename/(select dh_c_stylename from table where md5_at='男合计') else dh_c_sty_zb(原来的dh_c_sty_zb的计算方式)end

类似上面的做法,不过负载有些大,而且我不知道你的合计和占比是不是一起计算的,如果是,那么可能就要麻烦很多,个人建议可以用参数来计算这样会省些事情。比如将男合计先计算出来,然后转为一个参数,然后再计算合计的时候直接用,这样能省下很多事情。

文章标题:oracle怎么算占比,oracle 比例
文章源于:https://www.cdcxhl.com/article22/dsghccc.html

成都网站建设公司_创新互联,为您提供移动网站建设响应式网站面包屑导航小程序开发品牌网站建设营销型网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网站建设公司