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

需要帮助来计算单列

如何解决需要帮助来计算单列

我需要计算两个表中的单列。

代码片段

select 
    ((select count(Gender) from tableA) +
     (select Count(Gender) from tableB)) as Total Count

select 
    ((select Sum(Case when Gender = M then 1 else 0) from tableA) +    
     (select Sum(Case when Gender = M then 1 else 0) from tableB)) as Male Count

select 
    ((select Sum(Case when Gender = F then 1 else 0) from tableA) +    
     (select Sum(Case when Gender = F then 1 else 0) from tableB)) as Female Count
  1. 通过这些代码片段,我可以得到 3 个行集的结果。有没有办法在一个包含三列的单个行集中获得所有三个计数(总计数、男性计数、女性计数)?

  2. 其他场景,我需要根据不同的 if else 条件获取同一存储过程中相同列的计数。有没有办法获得这些计数,而不是为每个条件重复相同的代码

解决方法

看来你可以尝试联合这两个表并应用聚合。

SELECT COUNT(GENDER),SUM(CASE WHEN X.GENDER='MALE' THEN 1 ELSE 0 END)AS MALE_COUNT,SUM(CASE WHEN X.GENDER='FEMALE' THEN 1 ELSE 0 END)AS FEMALE_COUNT
 FROM
(
  select gender from tablea
  union all
  select gender from tableb  
)AS X

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