首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sql分组故障

Sql分组故障
EN

Stack Overflow用户
提问于 2014-07-22 06:11:27
回答 4查看 50关注 0票数 1

我遇到了sql脚本的麻烦,如下所示:

代码语言:javascript
复制
SELECT A, B, C,
 CASE WHEN D < 21 THEN '0<20'
      WHEN D < 51 THEN '21-50'
      WHEN D < 101 THEN '51-100'
      ELSE '>101' END AS E
 COUNT(*) FROM TABLE_X
GROUP BY A, B, C, D;

像这样的结果集;

代码语言:javascript
复制
     A  B   C     D   count(*)
    CAR 1   2   21-50   1
    CAR 1   2   21-50   1
   BIKE 1   3   0-20    1

在第一行是汽车有一个D=25.So,它是在21-50之间。然后第二排是汽车有D=32.So,它也在21-50之间。

不久,我想像上面这样的结果集:

代码语言:javascript
复制
    A   B   C     D   count(*)
   CAR  1   2   21-50   2
  BIKE  1   3   0-20    1

因此,汽车必须是2,分组为D列。

我怎么能保证呢?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2014-07-22 06:17:36

这里的问题是,您首先按照D进行分组,然后应用case逻辑进行分组。如果将D添加到select列表中,您将看到可能如下所示的结果:

代码语言:javascript
复制
     A  B   C     D     E    count(*)
    CAR 1   2    20   21-50    1
    CAR 1   2    30   21-50    1
   BIKE 1   3     7    0-20    1

为了避免这种情况,您可以先应用case,然后再应用group by子句,方法是使用子查询:

代码语言:javascript
复制
SELECT A, B, C, E, COUNT(*)
FROM   (SELECT A, B, C,
               CASE WHEN D < 21 THEN '0<20'
               WHEN D < 51 THEN '21-50'
               WHEN D < 101 THEN '51-100'
               ELSE '>101' END AS E
        FROM   TABLE_X) t
GROUP BY A, B, C, E;
票数 1
EN

Stack Overflow用户

发布于 2014-07-22 06:14:22

下面的查询应该可以工作。基本上,我只是将count(1)函数以及group子句拖到外部查询中,同时将所有rest功能留给内部查询。

代码语言:javascript
复制
SELECT A,B,C,E, count(1) from
(
  SELECT A, B, C,
  CASE WHEN D < 21 THEN '0<20'
      WHEN D < 51 THEN '21-50'
      WHEN D < 101 THEN '51-100'
      ELSE '>101' END AS E
  FROM TABLE_X
)
GROUP BY A, B, C, E;
票数 1
EN

Stack Overflow用户

发布于 2014-07-22 06:14:24

按D的计算分组,而不是D本身,如下所示:

代码语言:javascript
复制
SELECT A, B, C,
 CASE WHEN D < 21 THEN ' 0-20'
      WHEN D < 51 THEN '21-50'
      WHEN D < 101 THEN '51-100'
      ELSE '>101' END AS E
 ,COUNT(*) as "Coun"
 FROM TABLE_X
GROUP BY A, B, C, 
 CASE WHEN D < 21 THEN ' 0-20'
      WHEN D < 51 THEN '21-50'
      WHEN D < 101 THEN '51-100'
      ELSE '>101' END

产生这个

代码语言:javascript
复制
A    B           C           E      Count
---- ----------- ----------- ------ -----------
BIKE 1           3            0-20  1
CAR  1           2           21-50  2

在Server 2012中,在加载了以下值的表上运行时:

代码语言:javascript
复制
values
     ('CAR', 1,2,22)
    ,('CAR', 1,2,23)
    ,('BIKE',1,3,2)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24880116

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档