亲爱的朋友Stackoverflowers,
如何从场景中的同一个表中选择2个不同的计数:
x=a and x=b
具体来说,(WHEN type = subdomain)AND(WHEN subtype = subdomain)?
将它们添加到一起以创建’totalcount’?
我的尝试(供你参考):
SELECT description,type,count(1),subtype,count(2) FROM mapping,(dotcom WHERE type = subdomain) AS typecount,(dotcom WHERE subtype = subdomain) AS subtypecount GROUP BY description,subtype HAVING count(1)>1 AND count(2)>1 ORDER BY count(*) DESC LIMIT 10
第二次尝试:
SELECT description FROM mapping,SUM(WHEN subdomain = type OR subdomain = subtype) AS count(1) GROUP BY description,subtype HAVING count(1)>1 ORDER BY count(*) DESC LIMIT 10
解决方法
如果你有Postgres 9.4或更新版本,你可以使用FILTER,它比CASE WHEN … END语法更容易阅读.
SELECT description,COUNT(*) FILTER (WHERE subdomain = type) AS typecount,COUNT(*) FILTER (WHERE subtype = subdomain) AS subtypecount FROM mapping GROUP BY description,subtype;
应该注意的是,count(1)和count(2)并不像你想象的那样; count是一个聚合函数,它计算每一行中给定值是否为空,并且看到你给它一个整数字面值,它实际上只计算返回的行数.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。