微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

计算sql中的派生列

如何解决计算sql中的派生列

我有以下查询生成下表:-

select * from temp_3

bucket  values
OTIF+2  319
OTIF    24987              
null    1347               
OTIF+>2 515
OTIF+1  552

现在我需要这些值占我编写以下查询的总和的百分比:-

select sum(values) as total into temp_1 from temp_3
select bucket,(values/(select total from temp_1)) as score from temp_3

但这导致了以下结果:-

bucket  values
OTIF+2  0
OTIF    0              
null    0               
OTIF+>2 0
OTIF+1  0

谁能告诉我我们如何有效地将其转换为百分比形式?我哪里出错了?

解决方法

使用窗口函数:

select bucket,value,value * 1.0 / sum(value) over ()
from t;
,
select sum(values) as total into temp_1 from temp_3
select bucket,(values * 100) /total as score from temp_3,temp_1

或者只是

select bucket,(values * 100) /sum(values) as score from temp_3

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。