首页 > 解决方案 > 如何在选择 oracle 中将值分组到单行

问题描述

我有一个格式如下的表格:

place   stage   type
AFA11    1     TYPE_A                                                            
AFA11    2     TYPE_B                                                           
AFA12    1     TYPE_A                                                            
AFA12    2     TYPE_B   

我正在尝试的查询是:

SELECT place,
CASE when type = 'TYPE_A' THEN stage end type_A ,
CASE when type= 'TYPE_B' THEN stage end type_B 
FROM table  WHERE place LIKE '%AFA%'

但它是这样返回的:

place   type_A  type_B
AFA11    1       null
AFA11   null      2
AFA12    1       null
AFA12   null      2
                   

但我需要这样的回报:

place   type_A  type_B
AFA11     1       2
AFA12     1       2

我怎么能有这个回报?

标签: sqloraclecase

解决方案


您可以GROUP BY,并使用case 表达式进行条件聚合

SELECT place,
       MAX(CASE when type = 'TYPE_A' THEN stage end) type_A ,
       MAX(CASE when type= 'TYPE_B' THEN stage end) type_B 
FROM table  WHERE place LIKE '%AFA%'
GROUP BY place

推荐阅读