Entrada

MySQL 🐬 : Consultas Básicas

Como sabemos SQL (Structured Query Language) es un lenguaje estándar para gestionar bases de datos. Sin embargo, SQL es un conjunto de comandos que se organizan en diferentes sublenguajes que cumplen roles específicos.

A continuación tenemos un diagrama que nos muestra esos sublenguajes:

---
title: CATEGORÍAS DE COMANDOS SQL
---
graph TD
    B(<img src="" width="70" />)
    B-->C(<strong class="fs-3">DML</strong><br />Data Manipulation Language)
    B-->D(<strong class="fs-3">DDL</strong><br />Data Definition Language)
    B-->E(<strong class="fs-3">DCL</strong><br />Data Control Language)
    C-->CD[SELECT<br />INSERT<br />UPDATE<br />DELETE]
    D-->DD[CREATE<br />ALTER<br />DROP]
    E-->ED[GRANT<br />DENY<br />REVOKE]

¿Qué son las operaciones CRUD?

Las operaciones CRUD son los cuatros pilares fundamentales en la gestión de datos en una base de datos. CRUD es un acrónimo de las siguientes acciones:

  • Create (Crear): Insertar nuevos datos en una tabla.
  • Read (Leer): Consultar y obtener datos de una tabla.
  • Update (Actualizar): Modificar los datos existentes.
  • Delete (Eliminar): ELiminar datos de una tabla.

Antes de poder realizar cualquier operación CRUD, debemos crear una base de datos y definir la estructura de nuestras tablas.

Para crear una base de datos, usamos el comando CREATE DATABASE. A continuación, se muestra el ejemplo:

1
CREATE DATABASE empresa;

Este comando crea una base de datos llamada empresa. Para comenzar a usarla, debemos seleccionarla con el comando USE:

1
USE empresa;

Para que el prompt de MySQL muestre el nombre de la base de datos a la que estás conectado, puedes ejecutar el siguiente comando en la terminal prompt \u@\h [\d]>\_.

Ahora que tenemos nuestra base de datos, podemos crear tablas dentro de ella. Vamos a crear una tabla de empleados, donde almacenaremos información como el nombre, puesto, fecha de ingreso y su estado:

1
2
3
4
5
6
7
CREATE TABLE empleados (
    id INT AUTO_INCREMENT PRIMARY KEY,  -- ID único para cada empleado (auto incrementable)
    nombre VARCHAR(100) NOT NULL,       -- Nombre del empleado
    puesto VARCHAR(50),                 -- Puesto o cargo
    fecha_ingreso DATE,                 -- Fecha de ingreso del empleado
    activo BOOLEAN DEFAULT TRUE         -- Estado del empleado (activo o no)
);

1. Crear Datos (Insertar Registros)

La operación de crear datos en MySQL se realiza mediante el comando INSERT INTO. A continuación, tenemos ejemplos de cómo insertar datos en la table empleados que creamos previamente.

Insertar un solo registro

1
2
INSERT INTO empleados (nombre, puesto, fecha_ingreso)
VALUES ('Juan Pérez', 'Desarrollador', '2022-01-15');

En este caso, estamos insertando un registro en la tabla empleados con los siguientes valores:

  • nombre: Juan Pérez
  • puesto: Desarrollador
  • fecha_ingreso: 2022-01-15

El campo id se autoincrementa automáticamente y el campo activo se establece en TRUE por defecto.

Insertar múltiples registros

También es posible insertar múltiples en una sola consulta:

1
2
3
4
INSERT INTO empleados (nombre, puesto, fecha_ingreso)
VALUES
  ('Ana Gómez', 'Gerente', '2019-03-22'),
  ('Luis Díaz', 'Diseñador', '2021-07-10');

2. Leer Datos

La operación de leer datos se realiza mediante el comando SELECT. Podemos usar este comando para consultar toda la tabla o solo una parte de los datos.

Consultar todos los registros

Si queremos ver todos los registros de la tabla empleados, podemos usar la siguiente consulta:

1
SELECT * FROM empleados;

El (*) se utiliza para seleccionar todas las columnas de la tabla. El resultado incluirá todas las filas y columnas de la tabla empleados.

Consultar columnas específicas

Si solo necesitamos algunos datos, como el nombre y el puesto de los empleados, podemos especificar las columnas que queremos en la consulta:

1
SELECT nombre, puesto FROM empleados;

Filtrar resultados con WHERE

La cláusula WHERE nos permite filtrar los resultados según una condición específica. Por ejemplo, si queremos ver solo los empleados que tengas el puesto de “Desarrollador”, para ello podemos hacer lo siguiente:

1
SELECT nombre, puesto FROM empleados WHERE puesto = 'Desarrollador';

3. Actualizar datos

Ahora supongamos que queremos actualizar el puesto de Juan Pérez para que en vez de de Desarrollador sea Programador. La consulta sería la siguiente:

1
2
3
UPDATE empleados 
SET puesto = 'Programador'
WHERE nombre = 'Juan Pérez';

4. Eliminar Datos

Si necesitamos eliminar a Juan Pérez de la tabla, sería con el comando delete, usaríamos la siguiente consulta:

1
DELETE FROM empleados WHERE nombre = 'Juan Pérez';

Nunca olvides el where en este tipo de operaciones

Mi lema es

Esta entrada está licenciada bajo CC BY 4.0 por el autor.