本文介绍了Oracle 将行转为列的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有以下表格:

TABLE1
------
id name
1  n1
2  n2


TABLE2
------
id tipo valor
1  t1   v1
1  t2   v2
2  t1   v1
2  t2   v5
2  t3   v3

我正在努力:

id name t1 t2 t3
1  n1   v1 v2 -
2  n2   v1 v5 v3

有可能吗?我一直在寻找示例,但仍然没有弄清楚.

Is it possible? I have been looking examples but still I don't get nothing clear.

谢谢!

推荐答案

一种选择是使用 PIVOT Clause

One option would be using PIVOT Clause

SELECT *
  FROM (SELECT t1.*, t2.tipo, t2.valor
          FROM table1 t1
          JOIN table2 t2
            ON t2.id = t1.id)
 PIVOT
 (
  MAX(valor) FOR tipo IN ( 't1' AS "t1", 't2' AS "t2", 't3' AS "t3" )
 )

但这是静态的,例如.需要更新 tipo 列的不同值.为了使其动态化,您可以创建一个函数

but this is static, eg. needs to be updated as different values for tipo column is added. In order to make it dynamic, you can create a function

CREATE OR REPLACE FUNCTION Get_Pivoted_Cols RETURN SYS_REFCURSOR IS
  v_recordset SYS_REFCURSOR;
  v_sql       VARCHAR2(32767);
  v_cols      VARCHAR2(32767);
BEGIN
  SELECT LISTAGG( ''''||tipo||''' AS "'||tipo||'"' , ',' )
          WITHIN GROUP ( ORDER BY tipo )
    INTO v_cols
    FROM ( SELECT DISTINCT tipo FROM table2 );

  v_sql := 'SELECT *
              FROM (SELECT t1.*, t2.tipo, t2.valor
                      FROM table1 t1
                      JOIN table2 t2
                        ON t2.id = t1.id)
             PIVOT
             (
              MAX(valor) FOR tipo IN ( '|| v_cols ||' )
             )';

  OPEN v_recordset FOR v_sql;
  RETURN v_recordset;
END;
/

然后使用调用

VAR rc REFCURSOR
EXEC :rc := Get_Pivoted_Cols;
PRINT rc

来自 SQL 开发人员的控制台.

from SQL developer's console.

这篇关于Oracle 将行转为列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-01 15:26