Ir al contenido principal

Descubre el Poder de las Common Table Expressions (CTE) en SQL

 


En el mundo del análisis de datos y la gestión de bases de datos, SQL (Structured Query Language) sigue siendo una herramienta indispensable. Hoy, queremos compartir un truco impresionante que elevará tus habilidades en SQL: el uso de las Common Table Expressions (CTE). Este método no solo te permitirá simplificar consultas complejas, sino que también hará que tus datos sean más manejables y comprensibles.

¿Qué es una Common Table Expression (CTE)?

Una CTE, o Common Table Expression, es una función en SQL que permite definir una consulta temporal cuyo resultado puede ser referenciado dentro de la misma consulta. Las CTE se utilizan principalmente para mejorar la legibilidad y organización de las consultas SQL, especialmente cuando se trabaja con consultas recursivas o muy complejas.

Beneficios de Usar CTE

  1. Claridad y Organización: Las CTE hacen que las consultas largas y complicadas sean más legibles y fáciles de entender.
  2. Reutilización de Código: Puedes definir una CTE una vez y referenciarla múltiples veces en tu consulta principal.
  3. Facilidad en Consultas Recursivas: Las CTE son ideales para manejar estructuras de datos jerárquicas, como árboles genealógicos o organigramas.

Ejemplo Práctico: Encontrar la Jerarquía de Empleados

Imagina que tienes una tabla de empleados en tu empresa y quieres listar todos los empleados junto con su jerarquía. Aquí es donde una CTE recursiva brilla.

Estructura de la Tabla employees

CREATE TABLE employees ( employee_id INT PRIMARY KEY, employee_name VARCHAR(100), manager_id INT );

Datos de Ejemplo

INSERT INTO employees (employee_id, employee_name, manager_id) VALUES (1, 'CEO', NULL), (2, 'CTO', 1), (3, 'CFO', 1), (4, 'Engineer', 2), (5, 'Accountant', 3);

Consulta con WITH

WITH RECURSIVE EmployeeHierarchy AS ( SELECT employee_id, employee_name, manager_id, employee_name AS hierarchy FROM employees WHERE manager_id IS NULL UNION ALL SELECT e.employee_id, e.employee_name, e.manager_id, CONCAT(eh.hierarchy, ' -> ', e.employee_name) FROM employees e INNER JOIN EmployeeHierarchy eh ON e.manager_id = eh.employee_id ) SELECT * FROM EmployeeHierarchy;

Explicación del Código

  1. Definición del CTE:

    • La primera parte del WITH selecciona el nodo raíz de la jerarquía, en este caso, el CEO.
    • La segunda parte del WITH se une recursivamente con el CTE para construir la jerarquía completa.
  2. Consulta Principal:

    • Selecciona todos los datos generados por el CTE.

Resultados Esperados

employee_id | employee_name | manager_id | hierarchy ------------|---------------|------------|----------------------- 1 | CEO | NULL | CEO 2 | CTO | 1 | CEO -> CTO 3 | CFO | 1 | CEO -> CFO 4 | Engineer | 2 | CEO -> CTO -> Engineer 5 | Accountant | 3 | CEO -> CFO -> Accountant

Comentarios

Entradas populares de este blog

Tutorial: Introducción a PyTorch - Primeros Pasos en Deep Learning

  Muy interesado en este mundo de todo lo relacionado con inteligencia artificial hoy quiero que aprendamos juntos a utilizar PyTorch, una de las librerías más populares para Deep Learning, con ejemplos prácticos. En este tutorial iremos (porque yo también estoy aprendiendo) paso a paso para comenzar con PyTorch y construir nuestros primeros modelos de redes neuronales.  Bienvenido (a)!. El Deep Learning es una rama fascinante de la inteligencia artificial que ha logrado resultados impresionantes en una variedad de problemas complejos. En este tutorial, aprenderás a utilizar PyTorch, una potente librería de Python desarrollada por Facebook, para construir y entrenar modelos de deep learning desde cero. ¿Qué es PyTorch? PyTorch es una librería de Python para computación en Deep Learning que permite tanto entrenar modelos como usarlos para inferencia. Es conocida por su flexibilidad y facilidad de uso, lo que la convierte en una excelente opción tanto para investigadores como pa...

Las 10 Aplicaciones Más Descargadas en Google Play Store y Apple App Store en 2024

  En el mundo digital actual, las aplicaciones móviles juegan un papel crucial en nuestras vidas diarias. Con millones de aplicaciones disponibles, solo unas pocas logran destacar y acumular millones de descargas. En este artículo, exploramos las aplicaciones más descargadas en Google Play Store y Apple App Store hasta la primera mitad de 2024. 1. Instagram Instagram sigue siendo una de las aplicaciones más populares a nivel mundial. Con 696 millones de descargas en Google Play Store, esta plataforma de redes sociales permite a los usuarios compartir fotos y videos, interactuar con amigos y seguir a celebridades. 2. TikTok TikTok, la aplicación de videos cortos, ha revolucionado la forma en que consumimos contenido. Con 654 millones de descargas en Google Play Store, se mantiene como una de las favoritas entre los usuarios jóvenes y creativos. 3. Facebook Facebook, la red social pionera, continúa siendo relevante con 553 millones de descargas . La plataforma ofrece una variedad d...

Inyección SQL: Qué es y Cómo prevenirla

La inyección SQL es una de las vulnerabilidades de seguridad más peligrosas y comunes en aplicaciones web. Permite a los atacantes interferir con las consultas que una aplicación hace a su base de datos, lo que puede llevar a la exposición de datos sensibles y control total sobre la base de datos afectada. En este artículo, exploraremos qué es la inyección SQL, las nuevas técnicas que se están utilizando y cómo puedes proteger tu aplicación contra este tipo de ataques. ¿Qué es la Inyección SQL? La inyección SQL (SQL Injection) ocurre cuando un atacante inserta código SQL malicioso en un campo de entrada, el cual es luego ejecutado por la base de datos. Este tipo de ataque explota la falta de sanitización de entradas y permite a los atacantes acceder, modificar o eliminar datos de la base de datos. Nuevas Técnicas de Inyección SQL Con el tiempo, los atacantes han desarrollado nuevas técnicas para explotar las vulnerabilidades de inyección SQL. Algunas de las más recientes incluyen: Inye...