PostgreSQL 分组聚合查询中 filter 子句替换 case when

        PG聚合操作中的filter子句是ANSI SQL标准中的关键字,并不是PG的专用SQL关键字。如果我们想了解中国、美国、日本、法国、德国、加拿大从1960~2018年中每隔十年的GDP平均值情况,我们可能会写出着这样的SQL,

select country_name, sum(case when year>=1960 and year<1970 then gdp else null end) as "1960~1969",

  sum(case when year>=1970 and year<1980 then gdp else null end) as "1970~1979", 

  sum(case when year>=1980 and year<1990 then gdp else null end) as "1980~1989", 

  sum(case when year>=1990 and year<2000 then gdp else null end) as "1990~1999", 

  sum(case when year>=2000 then gdp else null end) as "2000~至今" 

from country_gdp_year_final 

where country_code in('CHN','JPN','U

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

地表最强菜鸡

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

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

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

打赏作者

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

抵扣说明:

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

余额充值