Amazon redshift 使用红移计算特定ID的字段中出现的值
我想计算某个ID的某个字段中出现的特定值。因此,我得到的是:Amazon redshift 使用红移计算特定ID的字段中出现的值,amazon-redshift,Amazon Redshift,我想计算某个ID的某个字段中出现的特定值。因此,我得到的是: | Location ID | Group | |:----------- |:---------| | 1 | Group A | | 2 | Group B | | 3 | Group C | | 4 | Group A | | 4 | Group B | | 4
| Location ID | Group |
|:----------- |:---------|
| 1 | Group A |
| 2 | Group B |
| 3 | Group C |
| 4 | Group A |
| 4 | Group B |
| 4 | Group C |
| 3 | Group A |
| 2 | Group B |
| 1 | Group C |
| 2 | Group A |
我希望通过一些计算机魔法得到的是:
| Location ID | Group A Count | Group B Count | Group C count|
|:----------- |:--------------|:--------------|:-------------|
| 1 | 1 | 0 | 1 |
| 2 | 1 | 2 | 0 |
| 3 | 1 | 0 | 1 |
| 4 | 1 | 1 | 1 |
是否可以在红移中使用某种旋转函数来实现这一点?这需要使用CASE函数和GROUP子句,如示例所示
SELECT l_id,
SUM(CASE WHEN l_group = 'Group A' THEN 1 ELSE 0 END) AS a,
SUM(CASE WHEN l_group = 'Group B' THEN 1 ELSE 0 END) AS b-- and so on
FROM location
GROUP BY l_id;
这会给您带来这样的结果:
| l_id | a | b |
|------|---|---|
| 4 | 1 | 1 |
| 1 | 1 | 0 |
| 3 | 1 | 0 |
| 2 | 1 | 2 |
你可以在这上面玩