PostgreSQL聚合函数的filter子句

PostgreSQL聚合函数的filter子句,第1张

概述一张表存储了学生id,科目,分数三个字段,求每个学生60分以下与参加的总科目占比。(今天电脑不好用,图片总是这样)   其实一个count(*) filter  就可以查出来,但是没用过PG的一个人竟然说我这么简单的SQL查询都不会,只是因为我没有用嵌套查询。回来总结了以下,自己想到了以下几种方法(只查询出了对应的数目没有做除法):   --filter函数 select stu_id, coun

一张表存储了学生ID,科目,分数三个字段,求每个学生60分以下与参加的总科目占比。(今天电脑不好用,图片总是这样)

 

其实一个count(*) filter  就可以查出来,但是没用过PG的一个人竟然说我这么简单的SQL查询都不会,只是因为我没有用嵌套查询。回来总结了以下,自己想到了以下几种方法(只查询出了对应的数目没有做除法):

 

--filter函数

select stu_ID,count(*),count(*) filter (where score<60) as "不及格"

from sherry.agg_filter

group by stu_ID

 

--使用case when

select stu_ID,sum(case when score<60 then 1 else 0) as "不及格"

from sherry.agg_filter group by stu_ID

 

--关联查询

select stu_ID,(select count(*) as c from sherry.agg_filter b where a.stu_ID = b.stu_ID and b.score < 60) as t2

from sherry.agg_filter a

group by a.stu_ID

 

--临时表关联

with raw as(

select stu_ID,count(*) as c1 from sherry.agg_filter

where score < 60

group by stu_ID

),

raw2 as(

select stu_ID,count(*) as c2

from sherry.agg_filter 

group by stu_ID)

select b.stu_ID,c1,c2

from raw a

right join raw2 b

on a.stu_ID = b.stu_ID

总结

以上是内存溢出为你收集整理的PostgreSQL聚合函数的filter子句全部内容,希望文章能够帮你解决PostgreSQL聚合函数的filter子句所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1163912.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存