0

我当前的结果集如下:

Case_ID    |   Action_name    |   Status_code

1             John                  Valid

1             Peter                 Valid

我希望这是

Case_ID      |    Action_name   |    Status_Code

1              John, Peter              Valid

或者也可以显示为

Case_ID       |  Action_name1   |   Action_name2   |   Status_code

1                   John               peter              Valid

任何可能的信息都会非常有帮助。我尝试了 Pivot 功能,但由于某些原因,我无法正确使用它。我知道我们可以在 SQL Server 中执行此操作,但我是 TOAD 数据点的新手。

4

1 回答 1

0

您没有指定您使用的数据库。如果是 Oracle,那么 LISTAGG 函数可能会有所帮助:

SQL> -- This is your current output:
SQL> with test (case_id, action_name, status_Code) as
  2     (select 1, 'John', 'valid' from dual union all
  3      select 1, 'Peter', 'valid' from dual
  4     )
  5  -- Adjust it using this:
  6  select
  7    case_id,
  8    listagg(action_name, ', ') within group (order by action_name) action_name,
  9    status_code
 10  from test
 11  group by case_id, status_code;

   CASE_ID ACTION_NAME                    STATU
---------- ------------------------------ -----
         1 John, Peter                    valid

SQL>

否则,看你的数据库是否提供了这样的聚合功能;我知道他们中的一些人这样做。

于 2019-04-18T22:18:24.733 回答