【问题标题】:Need help in getting count on single column需要帮助来计算单列
【发布时间】:2021-05-27 18:02:22
【问题描述】:

我需要从两个表中获取单个列的计数。

代码sn-p

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. 使用这些代码 sn-ps,我可以得到 3 个行集的结果。有没有办法在一个包含三列的行集中获得所有三个计数(总计数、男性计数、女性计数)?

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

【问题讨论】:

    标签: sql-server stored-procedures sql-server-2012


    【解决方案1】:

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

    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
    

    【讨论】:

    • 我尝试了交叉连接和它的到来。将尝试这种方法
    • @Sergey- 感谢您的建议。即使这种方法有效并且它节省了代码行。请让我知道我们是否可以做任何事情来获取计数,而不是重复相同的代码行来获取存储过程中不同条件的计数
    • 空白是免费的,你知道
    • @AMDI,很难给出一般性的建议。您能否举例说明您想要实现的目标
    猜你喜欢
    • 2012-10-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-08-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多