sql >> Base de Datos >  >> RDS >> Oracle

Transposición Oracle SQL

Sugeriría aplicar la función UNPIVOT primero a sus múltiples columnas, luego usar row_number() para crear sus nuevos nombres de columna que se usarán en PIVOT.

La sintaxis básica para deshacer el pivote será

select field, 
  value,
  'value'||
   to_char(row_number() over(partition by field
                              order by value)) seq
from yourtable
unpivot
(
  value
  for field in (Name, Age, Sex, DOB, col1, col2, col3)
) u;

Consulte SQL Fiddle con demostración . Esto convertirá sus múltiples columnas de datos en múltiples filas. Usé row_number() para crear un valor único para sus nuevos nombres de columna, los datos de esta consulta se ven así:

| FIELD |                   VALUE |    SEQ |
|-------|-------------------------|--------|
|   AGE |                      12 | value1 |
|   AGE |                      15 | value2 |
|  COL1 |                      aa | value1 |
|  COL1 |                      xx | value2 |

Luego puede aplicar la función PIVOT a este resultado:

select field, value1, value2
from
(
  select field, 
    value,
    'value'||
      to_char(row_number() over(partition by field
                                order by value)) seq
  from yourtable
  unpivot
  (
    value
    for field in (Name, Age, Sex, DOB, col1, col2, col3)
  ) u
) d
pivot
(
  max(value)
  for seq in ('value1' as value1, 'value2' as value2)
) piv

Consulte SQL Fiddle con demostración . Esto da un resultado final:

| FIELD |                  VALUE1 |                  VALUE2 |
|-------|-------------------------|-------------------------|
|   AGE |                      12 |                      15 |
|  COL1 |                      aa |                      xx |
|  COL2 |                      bb |                      yy |
|  COL3 |                      cc |                      zz |
|   DOB | 07-Aug-2001 12:00:00 AM | 26-Aug-2001 12:00:00 AM |
|  NAME |                       A |                       B |
|   SEX |                       F |                       M |

Tenga en cuenta que, cuando está aplicando la función de no pivotar, el tipo de datos de todas las columnas debe ser el mismo, por lo que es posible que deba convertir sus datos en una subconsulta antes de poder deshacer el pivote.

La función UNPIVOT/PIVOT se introdujo en Oracle 11g, si está utilizando Oracle 10g, puede editar la consulta para usar:

with cte as
(
  select 'name' field, name value
  from yourtable
  union all
  select 'Age' field, Age value
  from yourtable
  union all
  select 'Sex' field, Sex value
  from yourtable
  union all
  select 'DOB' field, DOB value
  from yourtable
  union all
  select 'col1' field, col1 value
  from yourtable
  union all
  select 'col2' field, col2 value
  from yourtable
  union all
  select 'col3' field, col3 value
  from yourtable
)
select
  field,
  max(case when seq = 'value1' then value end) value1,
  max(case when seq = 'value2' then value end) value2
from
(
  select field, value,
  'value'||
      to_char(row_number() over(partition by field
                                order by value)) seq
  from cte
) d
group by field;

Consulte SQL Fiddle con demostración