· Andrés Ledo · MySQL  · Lectura en 8 min

Cómo usar el comando SELECT de MySQL para consultar datos de una base de datos

Descubre el comando SELECT en MySQL como nunca antes con nuestra guía completa. Ejemplos prácticos, estrategias avanzadas y mucho más.

Descubre el comando SELECT en MySQL como nunca antes con nuestra guía completa. Ejemplos prácticos, estrategias avanzadas y mucho más.

MySQL es un sistema de gestión de bases de datos relacionales que permite almacenar, modificar y recuperar datos de una forma eficiente y segura. Una de las operaciones más comunes que se realizan con MySQL es la consulta de datos, es decir, la extracción de información de una o más tablas de una base de datos. Para ello, se utiliza el comando SELECT, que tiene una sintaxis y unas opciones muy variadas y flexibles.

En este artículo, vamos a explicar cómo usar el comando SELECT de MySQL para consultar datos de una base de datos, mostrando ejemplos prácticos y consejos útiles. Para seguir este tutorial, se recomienda tener instalado MySQL en tu ordenador y tener acceso a una base de datos con algunas tablas y registros. Si no sabes cómo hacerlo, puedes consultar este artículo que te enseña cómo instalar y configurar MySQL.

Índice

¿Qué es el comando SELECT de MySQL?

El comando SELECT de MySQL es una instrucción SQL (Structured Query Language) que se utiliza para seleccionar los datos que se quieren obtener de una o más tablas de una base de datos. El comando SELECT tiene la siguiente sintaxis general:

SELECT columnas
FROM tablas
WHERE condiciones
GROUP BY columnas
HAVING condiciones
ORDER BY columnas
LIMIT número;

Los elementos entre corchetes son opcionales y se pueden omitir según las necesidades de la consulta. A continuación, explicamos el significado y el uso de cada uno de ellos:

  • columnas: son los nombres de las columnas o campos que se quieren mostrar en el resultado de la consulta. Se pueden especificar varias columnas separadas por comas, o se puede usar el símbolo * para seleccionar todas las columnas disponibles.

  • tablas: son los nombres de las tablas o vistas que contienen los datos que se quieren consultar. Se pueden especificar varias tablas separadas por comas, o se puede usar la cláusula JOIN para combinar los datos de varias tablas relacionadas.

  • condiciones: son las expresiones lógicas que determinan qué registros o filas se quieren incluir en el resultado de la consulta. Se pueden usar operadores de comparación, lógicos y aritméticos, así como funciones y subconsultas. La cláusula WHERE se usa para filtrar los registros antes de agruparlos o ordenarlos, mientras que la cláusula HAVING se usa para filtrar los registros después de agruparlos.

  • GROUP BY: es la cláusula que permite agrupar los registros por una o más columnas, generalmente para aplicar funciones de agregación como SUM, COUNT, AVG, MIN o MAX. Estas funciones permiten obtener valores estadísticos o resumidos de los datos.

  • ORDER BY: es la cláusula que permite ordenar los registros por una o más columnas, en orden ascendente (ASC) o descendente (DESC). El orden por defecto es ascendente.

  • LIMIT: es la cláusula que permite limitar el número de registros que se muestran en el resultado de la consulta. Se puede especificar un solo número para indicar el máximo de registros, o dos números separados por comas para indicar el inicio y el final del intervalo.

Ejemplos prácticos del uso del comando SELECT

Para ilustrar el uso del comando SELECT, vamos a utilizar una base de datos llamada “tienda”, que contiene tres tablas: “clientes”, “productos” y “ventas”. La estructura y algunos datos de estas tablas son los siguientes:

idnombreemailtelefono
1Ana[email protected]555111222
2Luis[email protected]555333444
3Pedro[email protected]555555666

Tabla “clientes”

idnombrepreciostock
1Camiseta10.0020
2Pantalón20.0015
3Zapatos30.0010

Tabla “productos”

idcliente_idproducto_idcantidadfecha
11122023-01-01
22212023-01-02
33322023-01-03

Tabla “ventas”

Ejemplo 1: Seleccionar todas las columnas de una tabla

Para seleccionar todas las columnas de una tabla, se puede usar el símbolo * en lugar de los nombres de las columnas. Por ejemplo, para mostrar todos los datos de la tabla “clientes”, se puede usar el siguiente comando:

SELECT * FROM clientes;

El resultado sería el siguiente:

idnombreemailtelefono
1Ana[email protected]555111222
2Luis[email protected]555333444
3Pedro[email protected]555555666

Ejemplo 2: Seleccionar algunas columnas de una tabla

Para seleccionar algunas columnas de una tabla, se deben especificar los nombres de las columnas separados por comas. Por ejemplo, para mostrar solo el nombre y el email de los clientes, se puede usar el siguiente comando:

SELECT nombre, email FROM clientes;

El resultado sería el siguiente:

nombreemail
Ana[email protected]
Luis[email protected]
Pedro[email protected]

Ejemplo 3: Seleccionar registros que cumplan una condición

Para seleccionar registros que cumplan una condición, se debe usar la cláusula WHERE seguida de la expresión lógica que define la condición. Por ejemplo, para mostrar los datos de los clientes que tienen un nombre que empieza por “A”, se puede usar el siguiente comando:

SELECT * FROM clientes WHERE nombre LIKE 'A%';

El resultado sería el siguiente:

idnombreemailtelefono
1Ana[email protected]555111222

En este caso, se ha usado el operador LIKE para buscar un patrón en el texto, y el símbolo % para indicar cualquier carácter o conjunto de caracteres. Se pueden usar otros operadores de comparación como =, <>, <, >, <=, >=, IN, BETWEEN, etc.

Ejemplo 4: Seleccionar registros que cumplan varias condiciones

Para seleccionar registros que cumplan varias condiciones, se deben usar los operadores lógicos AND, OR y NOT para combinar las expresiones lógicas que definen las condiciones. Por ejemplo, para mostrar los datos de los clientes que tienen un nombre que empieza por “A” o un email que contiene “yahoo”, se puede usar el siguiente comando:

SELECT * FROM clientes WHERE nombre LIKE 'A%' OR email LIKE '%yahoo%';

El resultado sería el siguiente:

idnombreemailtelefono
1Ana[email protected]555111222
3Pedro[email protected]555555666

Ejemplo 5: Seleccionar registros de varias tablas

Para seleccionar registros de varias tablas, se deben especificar los nombres de las tablas separados por comas, o usar la cláusula JOIN para combinar los datos de las tablas relacionadas. Por ejemplo, para mostrar el nombre del cliente y el nombre del producto de cada venta, se puede usar el siguiente comando:

SELECT c.nombre AS cliente, p.nombre AS producto
FROM ventas v
JOIN clientes c ON v.cliente_id = c.id
JOIN productos p ON v.producto_id = p.id;

El resultado sería el siguiente:

clienteproducto
AnaCamiseta
LuisPantalón
PedroZapatos

En este caso, se ha usado la cláusula JOIN para unir las tablas por sus claves foráneas, y se ha usado la palabra clave AS para asignar alias a las columnas y evitar ambigüedades. Se pueden usar diferentes tipos de JOIN según la forma en que se quieran combinar los datos: INNER JOIN, LEFT JOIN, RIGHT JOIN o FULL JOIN.

Ejemplo 6: seleccionar registros agrupados por una columna

Para seleccionar registros agrupados por una columna, se debe usar la cláusula GROUP BY seguida del nombre de la columna por la que se quiere agrupar. Por ejemplo, para mostrar el número de ventas por cliente, se puede usar el siguiente comando:

SELECT c.nombre AS cliente, COUNT(v.id) AS ventas
FROM ventas v
JOIN clientes c ON v.cliente_id = c.id
GROUP BY c.nombre;

El resultado sería el siguiente:

clienteventas
Ana1
Luis1
Pedro1

En este caso, se ha usado la función de agregación COUNT para contar el número de ventas de cada cliente, y se ha agrupado por el nombre del cliente. Se pueden usar otras funciones de agregación como SUM, AVG, MIN o MAX.

Ejemplo 7: seleccionar registros agrupados por varias columnas

Para seleccionar registros agrupados por varias columnas, se deben especificar los nombres de las columnas separadas por comas en la cláusula GROUP BY. Por ejemplo, para mostrar el total de ventas por cliente y por producto, se puede usar el siguiente comando:

SELECT c.nombre AS cliente, p.nombre AS producto, SUM(v.cantidad) AS total
FROM ventas v
JOIN clientes c ON v.cliente_id = c.id
JOIN productos p ON v.producto_id = p.id
GROUP BY c.nombre, p.nombre;

El resultado sería el siguiente:

clienteproductototal
AnaCamiseta2
LuisPantalón1
PedroZapatos2

En este caso, se ha usado la función de agregación SUM para sumar las cantidades de cada venta, y se ha agrupado por el nombre del cliente y el nombre del producto. Se pueden usar otras funciones de agregación como COUNT, AVG, MIN o MAX.

Ejemplo 8: seleccionar registros ordenados por una columna

Para seleccionar registros ordenados por una columna, se debe usar la cláusula ORDER BY seguida del nombre de la columna y la dirección del orden (ASC o DESC). Por ejemplo, para mostrar los productos ordenados por su precio de menor a mayor, se puede usar el siguiente comando:

SELECT * FROM productos ORDER BY precio ASC;

El resultado sería el siguiente:

idnombrepreciostock
1Camiseta10.0020
2Pantalón20.0015
3Zapatos30.0010

En este caso, se ha usado la dirección ASC para indicar un orden ascendente. Se puede usar la dirección DESC para indicar un orden descendente.

Ejemplo 9: seleccionar registros limitados por un número

Para seleccionar registros limitados por un número, se debe usar la cláusula LIMIT seguida del número máximo de registros que se quieren mostrar. Por ejemplo, para mostrar solo los tres primeros clientes ordenados alfabéticamente por su nombre, se puede usar el siguiente comando:

SELECT * FROM clientes ORDER BY nombre ASC LIMIT 3;

El resultado sería el siguiente:

idnombreemailtelefono
1Ana[email protected]555111222
2Luis[email protected]555333444
3Pedro[email protected]555555666

En este caso, se ha usado la cláusula LIMIT para indicar que solo se quieren mostrar tres registros. Se puede especificar también el inicio del intervalo con otro número separado por una coma. Por ejemplo, para mostrar los tres siguientes clientes ordenados alfabéticamente por su nombre, se puede usar el siguiente comando:

SELECT * FROM clientes ORDER BY nombre ASC LIMIT 3,3;

El resultado sería vacío, ya que no hay más clientes en la tabla.


En este artículo, hemos visto cómo usar el comando SELECT de MySQL para consultar datos de una base de datos, mostrando ejemplos prácticos y consejos útiles. El comando SELECT es una herramienta muy poderosa y flexible que permite extraer información relevante y personalizada de una o más tablas de una base de datos. Con el comando SELECT se pueden seleccionar las columnas que se quieren mostrar, filtrar los registros que cumplen ciertas condiciones, combinar los datos de varias tablas relacionadas, agrupar los registros por una o más columnas, ordenar los registros por una o más columnas y limitar el número de registros que se quieren mostrar. Con estas opciones, se pueden realizar consultas muy variadas y complejas que respondan a las necesidades de cada caso.

Esperamos que este artículo te haya sido útil y que te ayude a mejorar el posicionamiento de tu sitio web. Si tienes alguna duda o sugerencia, puedes dejar un comentario abajo.

Articulos relacionados:

Este artículo forma parte del tutorial de MySQL.

    Compartir
    Volver al blog

    Artículos relacionados

    Ver todos los artículos »
    Validar DNI, NIE y CIF online

    Validar DNI, NIE y CIF online

    En España, validar la autenticidad de documentos como el DNI, NIE y CIF es crucial para cumplir con las regulaciones y prevenir fraudes. Las...

    ¿Qué es un Dominio Web?

    ¿Qué es un Dominio Web?

    Un dominio web básicamente se encarga de traducir una dirección IP que sería la que identifica a tu servidor, a un nombre de dominio o un texto que...

    PHP Headers guía básica

    PHP Headers guía básica

    Domina la función header() en PHP para manipular las cabeceras HTTP en tus scripts. Aprende a gestionar redirecciones, tipos de contenido, caché y...

    PHP Switch

    PHP Switch

    Aprende a usar la estructura de control de flujo "switch" en PHP para evaluar expresiones y ejecutar código en función de los resultados. Conoce sus...