SQL GROUP BY: cómo agrupar valores idénticos

Si deseas agrupar filas con valores idénticos, SQL GROUP BY es la instrucción adecuada. Suele utilizarse en combinación con funciones de agregación.

¿Qué es SQL GROUP BY?

En el Structured Query Language, SQL GROUP BY es una instrucción que se utiliza para agrupar filas con valores idénticos. Se utiliza con el comando SQL SELECT y sigue a la instrucción WHERE. SQL GROUP BY se utiliza a menudo en combinación con funciones como SQL AVG(), SQL COUNT(), MAX(), MIN() o SUM(). Esto te permite realizar cálculos y mostrar los resultados dentro de tu tabla. La instrucción es muy útil si se quiere determinar una instrucción o relacionar valores entre sí.

Servidores virtuales VPS
Virtualización completa con acceso root
  • Ancho de banda de hasta 1 Gb/s y tráfico ilimitado
  • Almacenamiento SSD NVMe ultrarrápido
  • Incluye: edición Plesk Web Host

Sintaxis y funcionalidad

La sintaxis básica de SQL GROUP BY es la siguiente:

SELECT columna1, columna2, columna3, …  
FROM nombre_de_tabla  
GROUP BY columna1, columna2, columna3, …;
sql

Sin embargo, la versión con una cláusula WHERE, que permite integrar determinadas condiciones, es mucho más común:

SELECT columna1, columna2, columna3, …  
FROM nombre_de_tabla  
WHERE condición  
GROUP BY columna1, columna2, columna3, …  
ORDER BY columna1, columna2, columna3, …;
sql

Ejemplo de uso con COUNT()

Para ilustrar cómo puedes utilizar SQL GROUP BY, crearemos una tabla sencilla llamada “Lista de clientes”. Ésta contiene columnas para el número de cliente, el nombre, la ubicación y los artículos comprados:

Número de cliente Nombre Ubicación Artículo
1427 Santos Nueva York 13
1377 Johnson Los Ángeles 9
1212 Brown Los Ángeles 15
1431 Davis Chicago 22
1118 Martínez Nueva York 10

Ahora podemos utilizar SQL GROUP BY en combinación con la función COUNT(), por ejemplo, para listar cuántos clientes proceden de qué ciudades. He aquí el código correspondiente:

SELECT Ubicación, COUNT(*) AS Cantidad  
FROM Lista_de_clientes  
GROUP BY Ubicación;
sql

Como resultado, obtenemos esta nueva tabla:

Ubicación Cantidad
Chicago 1
Nueva York 2
Los Ángeles 2

Hemos utilizado SQL Aliases para mostrar los resultados como un “número”.

La sentencia junto con SUM()

En el siguiente ejemplo, utilizamos SQL GROUP BY en combinación con SUM() para determinar y mostrar cuántos artículos se pidieron a Los Ángeles:

SELECT Ubicación, SUM(Artículo) AS Total  
FROM Lista_de_clientes  
WHERE Ubicación = 'Los Ángeles'  
GROUP BY Ubicación;
sql

Como resultado obtenemos:

Ubicación Total
Los Ángeles 24

Uso con ORDER BY

También es posible una combinación con ORDER BY. Para nuestra tabla, ordenamos por el mayor número de artículos pedidos por cliente y por ciudad. Empezamos por la localidad en la que un cliente ha comprado más artículos. El código correspondiente, para el que combinamos SQL GROUP BY con la función MAX() y ORDER BY, es este:

SELECT Ubicación, MAX(Artículo) AS MayorCantidad  
FROM Lista_de_clientes  
GROUP BY Ubicación ORDER BY MayorCantidad DESC;
sql

Y el resultado sería:

Ubicación Mayor cantidad
Chicago 22
Los Ángeles 15
Nueva York 13

En combinación con HAVING

También puedes combinar SQL GROUP BY con SQL HAVING. En el siguiente ejemplo, eliminamos de la lista aquellos clientes cuyo número de cliente es inferior a 1300. Ordenamos las personas restantes según el número de artículos que han pedido en orden ascendente:

SELECT Ubicación, Número de cliente, MIN(Artículo) AS MenorCantidad  
FROM Lista_de_clientes  
GROUP BY Ubicación, Número_de_cliente HAVING Número_de_cliente > 1300;
sql

Obtenemos esta tabla como nuevo resultado:

Ubicación Número de cliente Menor cantidad
Los Ángeles 1377 9
Nueva York 1427 13
Chicago 1431 22

Alternativas a SQL GROUP BY

Una alternativa popular a SQL GROUP BY es la sentencia PARTITION BY. La diferencia es que todos los valores originales se conservan y se muestran. Además, muchas de las funciones agregadas mencionadas anteriormente también funcionan sin SQL GROUP BY.

Consejo

Una base de datos a tu medida: con el Hosting SQL Server de IONOS, no solo podrás elegir entre MSSQL, MySQL o MariaDB, sino que también te beneficiarás de un rendimiento extraordinario, sólidas funciones de seguridad y asesoramiento personal.

¿Le ha resultado útil este artículo?
Utilizamos cookies propias y de terceros para mejorar nuestros servicios y mostrarle publicidad relacionada con sus preferencias mediante el análisis de sus hábitos de navegación. Si continua navegando, consideramos que acepta su uso. Puede obtener más información, o bien conocer cómo cambiar la configuración de su navegador en nuestra. Política de Cookies.
Page top