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 tablaempleados
.
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