我遇到了sql脚本的麻烦,如下所示:
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;像这样的结果集;
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之间。
不久,我想像上面这样的结果集:
A B C D count(*)
CAR 1 2 21-50 2
BIKE 1 3 0-20 1因此,汽车必须是2,分组为D列。
我怎么能保证呢?
发布于 2014-07-22 06:17:36
这里的问题是,您首先按照D进行分组,然后应用case逻辑进行分组。如果将D添加到select列表中,您将看到可能如下所示的结果:
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子句,方法是使用子查询:
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;发布于 2014-07-22 06:14:22
下面的查询应该可以工作。基本上,我只是将count(1)函数以及group子句拖到外部查询中,同时将所有rest功能留给内部查询。
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;发布于 2014-07-22 06:14:24
按D的计算分组,而不是D本身,如下所示:
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产生这个
A B C E Count
---- ----------- ----------- ------ -----------
BIKE 1 3 0-20 1
CAR 1 2 21-50 2在Server 2012中,在加载了以下值的表上运行时:
values
('CAR', 1,2,22)
,('CAR', 1,2,23)
,('BIKE',1,3,2)https://stackoverflow.com/questions/24880116
复制相似问题