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í.
- 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, …;
sqlSin 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, …;
sqlEjemplo 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;
sqlComo 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;
sqlComo 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;
sqlY 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;
sqlObtenemos 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.
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.