Over 10 years we helping companies reach their financial and branding goals. Onum is a values-driven SEO agency dedicated.

CONTACTS
Oracle

Oracle UNPIVOT: Practical Examples & Transpose in Oracle SQL

En este tutorial, exploraremos en detalle la cláusula UNPIVOT de Oracle, una poderosa herramienta que nos permite transponer columnas en filas en una tabla. Conocer cómo utilizar esta cláusula es fundamental para cualquier desarrollador que trabaje con Oracle SQL, ya que brinda flexibilidad y eficiencia al momento de manejar datos en diferentes formatos y estructuras.

¿Qué es la cláusula UNPIVOT de Oracle?

La cláusula UNPIVOT de Oracle es una funcionalidad que nos permite cambiar la estructura de una tabla al transponer las columnas en filas. En otras palabras, nos permite convertir los valores de las columnas en filas para facilitar el análisis y manipulación de los datos.

La sintaxis de la cláusula UNPIVOT consta de tres componentes principales: unpivot_clause, unpivot_for_clause y unpivot_in_clause. Estos componentes nos permiten especificar las columnas a transponer, los valores que se van a mostrar como filas y los nombres de las columnas resultantes.

Además, la cláusula UNPIVOT nos da la opción de incluir o excluir filas nulas utilizando las cláusulas INCLUDE o EXCLUDE NULLS. Esto es útil cuando deseamos filtrar los datos que queremos transponer o cuando los valores nulos no son relevantes para nuestro análisis.

Sintaxis de la cláusula UNPIVOT

La sintaxis básica de la cláusula UNPIVOT en Oracle es la siguiente:

SELECT column1, column2, ...
FROM table_name
UNPIVOT (
value_column
FOR (new_column1, new_column2, ...)
IN (old_column1 AS 'new_value1', old_column2 AS 'new_value2', ...)
);

En esta sintaxis, column1, column2, ... representan las columnas que deseamos mantener en el resultado final. table_name es el nombre de la tabla que contiene los datos que queremos transponer.

Recomendado:  Descubre cómo gestionar y utilizar los packages de Oracle

Luego, la cláusula UNPIVOT indica que queremos realizar la transposición. value_column especifica la columna que queremos transponer y que se mostrará como filas en el resultado final.

La cláusula FOR especifica los nombres de las nuevas columnas que contendrán los valores transpuestos. Estos nombres se utilizan para referirse a las columnas en el resultado final.

La cláusula IN se utiliza para asignar los valores de las columnas originales a las nuevas columnas. Cada par old_column AS 'new_value' define el valor de una columna original y su equivalente en la nueva columna.

Finalmente, podemos utilizar las cláusulas INCLUDE o EXCLUDE NULLS para determinar si queremos incluir o excluir filas con valores nulos en el resultado final.

Inclusión y exclusión de filas nulas

La cláusula UNPIVOT de Oracle nos ofrece la posibilidad de incluir o excluir filas nulas en el resultado final mediante el uso de las cláusulas INCLUDE o EXCLUDE NULLS.

Si queremos incluir filas con valores nulos en el resultado, podemos utilizar la cláusula INCLUDE NULLS. Esto significa que las filas con valores nulos serán mostradas como parte del resultado final. Esta opción es útil cuando los valores nulos tienen algún significado importante o cuando queremos mantener la integridad de los datos originales.

Por otro lado, si deseamos excluir filas con valores nulos, podemos utilizar la cláusula EXCLUDE NULLS. Con esta opción, las filas con valores nulos no se mostrarán en el resultado final. Esta opción es útil cuando queremos filtrar los datos y trabajar solo con los valores no nulos.

El uso de estas cláusulas es opcional y depende de los requisitos específicos de cada situación. Pueden ser utilizadas según nuestras necesidades, permitiendo tener un control preciso sobre qué filas se incluyen o excluyen en el resultado final.

Recomendado:  Guía definitiva de Oracle GROUP BY: Ejemplos y funciones

Ejemplos de uso de la cláusula UNPIVOT

A continuación, presentaremos algunos ejemplos prácticos de cómo utilizar la cláusula UNPIVOT en Oracle para transponer columnas en filas.

Ejemplo 1:

Supongamos que tenemos una tabla llamada «ventas» con las siguientes columnas: «producto», «mes1», «mes2», «mes3». Queremos transponer las columnas de los meses en filas para obtener una tabla con las columnas «producto», «mes» y «cantidad». La cláusula UNPIVOT nos facilita esta tarea:

sql
SELECT producto, mes, cantidad
FROM ventas
UNPIVOT (
cantidad
FOR mes IN (mes1 AS ‘Enero’, mes2 AS ‘Febrero’, mes3 AS ‘Marzo’)
);

En este ejemplo, estamos transponiendo las columnas «mes1», «mes2» y «mes3» en la nueva columna «mes», que contendrá los valores ‘Enero’, ‘Febrero’ y ‘Marzo’. La columna «cantidad» contendrá los valores originalmente presentes en las columnas transpuestas.

Ejemplo 2:

Supongamos que tenemos una tabla llamada «empleados» con las siguientes columnas: «id_empleado», «nombre», «salario_anual», «bonus_anual». Queremos transponer las columnas «salario_anual» y «bonus_anual» en filas para obtener una tabla con las columnas «id_empleado», «tipo», «monto». La cláusula UNPIVOT nos permite lograr esto:

sql
SELECT id_empleado, tipo, monto
FROM empleados
UNPIVOT (
monto
FOR tipo IN (salario_anual AS ‘Salario’, bonus_anual AS ‘Bonus’)
);

En este ejemplo, estamos transponiendo las columnas «salario_anual» y «bonus_anual» en la nueva columna «tipo», que contendrá los valores ‘Salario’ y ‘Bonus’. La columna «monto» contendrá los valores correspondientes a los salarios anuales y bonificaciones anuales de los empleados.

Estos ejemplos ilustran cómo la cláusula UNPIVOT nos permite flexibilidad al transponer columnas en filas y obtener una nueva visualización de los datos.

Transponiendo múltiples columnas

La cláusula UNPIVOT de Oracle también nos permite transponer múltiples columnas en filas de manera simultánea. Esto es útil cuando tenemos varias columnas que queremos transponer al mismo tiempo. A continuación, presentaremos un ejemplo de cómo hacerlo:

Recomendado:  Oracle CHR Function: Practical Examples & Syntax | SQL CHR

sql
SELECT id, tipo, cantidad
FROM tabla_origen
UNPIVOT(
cantidad
FOR tipo IN (columna1 AS ‘Tipo1’, columna2 AS ‘Tipo2’, columna3 AS ‘Tipo3’)
);

En este ejemplo, la tabla original llamada «tabla_origen» tiene las columnas «id», «columna1», «columna2» y «columna3». Supongamos que queremos transponer las columnas «columna1», «columna2» y «columna3» en filas para obtener una tabla con las columnas «id», «tipo» y «cantidad». La cláusula UNPIVOT nos permite lograr esto.

La cláusula FOR tipo IN (columna1 AS 'Tipo1', columna2 AS 'Tipo2', columna3 AS 'Tipo3') especifica que queremos transponer las columnas «columna1», «columna2» y «columna3» en la nueva columna «tipo», y asignar a cada una de ellas un nombre específico: «Tipo1», «Tipo2» y «Tipo3». La columna «cantidad» contendrá los valores correspondientes a cada una de las columnas transpuestas.

De esta forma, utilizando la cláusula UNPIVOT y especificando las columnas que queremos transponer, podemos obtener una tabla con una nueva estructura en la que las columnas originales se convierten en filas.

Conclusión

La cláusula UNPIVOT de Oracle nos brinda una herramienta poderosa para transponer columnas en filas en una tabla. Nos permite cambiar la estructura de los datos y obtener una nueva visualización de los mismos, lo cual puede ser útil en diversas situaciones de análisis y manipulación de datos.

En este tutorial, hemos explorado la sintaxis de la cláusula UNPIVOT, que incluye la unpivot_clause, unpivot_for_clause y unpivot_in_clause. También hemos visto cómo utilizar las cláusulas INCLUDE y EXCLUDE NULLS para incluir o excluir filas nulas en el resultado final.

Además, hemos presentado ejemplos prácticos de cómo utilizar la cláusula UNPIVOT para transponer columnas en filas en una tabla de muestra, así como también hemos mostrado cómo transponer múltiples columnas al mismo tiempo.

Este tutorial ha ofrecido instrucciones detalladas sobre cómo utilizar la cláusula UNPIVOT de Oracle y cómo aprovechar al máximo esta funcionalidad para transformar y analizar nuestros datos de manera eficiente.

Autor

osceda@hotmail.com

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *