Amazon redshift 使用红移计算特定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

我想计算某个ID的某个字段中出现的特定值。因此,我得到的是:

| 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 |
你可以在这上面玩