MySQL 🐬 : Trabajar con fechas
MySQL cuando almacena una fecha lo hace de acuerdo a la norma ISO_8601 lo que quiere decir en el formato YYYY-mm-dd
.
La siguiente tabla contiene algunas de las funciones de fecha y hora que soporta MySQL:
Nombre | Descripción |
---|---|
ADDDATE() | Agrega valores de tiempo (intervalos) a un valor de fecha. |
CURDATE() | Obtiene la fecha actual sin la parte de la hora. |
CURRENT_DATE , CURRENT_DATE() | Son sínonimos de CURDATE() |
DATE() | Extrae la parte de la fecha de una expresión de fecha o fecha y hora. |
DATEDIFF() | Resta dos fechas. |
DATE_FORMAT() | Formatear a una fecha de acuerdo a un formato especificado. |
EXTRACT() | Extraer parte de una fecha. |
ADDDATE
La función ADDDATE()
es similar a DATE_ADD()
, y se utiliza para agregar un intervalo de tiempo a una fecha. En términos de funcionalidad, ambas hacen lo mismo, pero la sintaxis es ligeramente diferente-
Sintaxis de ADDDATE()
1
ADDDATE(fecha, INTERVAL valor unidad)
- fecha: La fecha a la que le vamos agregar el intervalo
- valor: La cantidad de unidades que deseamos agregar.
- unidad: El tipo de unidad, como
DAY
,MONTH
,YEAR
,HOUR
,MINUTE
,SECOND
, entre otros.
Ejemplo de uso
- Agregar días a una fecha:
1
SELECT ADDDATE('2020-01-02', INTERVAL 31 DAY);
- Resultado:
2020-02-02
- Acción: suma 31 días a la fecha
2020-12-01
- Agregar meses a una fecha:
1
SELECT ADDDATE('2020-12-01', INTERVAL 3 MONTH);
- Resultado:
2021-03-01
- Acción: suma 3 meses a la fecha
2020-12-01
La función
ADDDATE()
es útil para cálculos de fechas futuras o pasadas a partir de una fecha base.
CURDATE
Devuelve el valor actual de la fecha en el formato YYYY-MM-DD
o YYYYMMDD
dependiendo si la función se usa en el contexto de cadena o numérico.
1
SELECT CURDATE();
Ejemplo de uso
- Insertar en una Tabla usando la función
CURDATE()
:
1
2
3
4
5
6
7
8
9
10
11
/* Considerando tener la siguiente tabla */
CREATE TABLE `users`(
`user_id` INT(11) NOT NULL,
`username` VARCHAR(10) NOT NULL,
`up` DATE,
`status` BOOLEAN
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/* Usamos la función CURDATE() en el campo up: */
INSERT INTO `users` (`user_id`, `username`, `up`, `status`)
VALUES (1010010101, 'Jhon Doe', CURDATE(), 1);
Al hacer un select
a la tabla users
, obtenemos el registro guardado anteriormente y en el campo up
muestra la fecha actual de ese momento en que se grabo en la base de datos el registro:
1
2
3
4
5
+------------+----------+------------+--------+
| user_id | username | up | status |
+------------+----------+------------+--------+
| 1010010101 | Jhon Doe | 2023-12-05 | 1 |
+------------+----------+------------+--------+
DATE
Extrae la parte de la fecha en una expresión de fecha y hora.
Ejemplo de uso
- Extraer la fecha de un campo fecha y hora:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
CREATE TABLE `users`(
`user_id` INT(11) NOT NULL,
`username` VARCHAR(10) NOT NULL,
`birthday` DATE NOT NULL,
`up` DATETIME NOT NULL,
`status` BOOLEAN
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/* Insertar valores usando la función CURRENT_TIMESTAMP en el campo up */
INSERT INTO `users` (`user_id`, `username`, `birthday`, `up`, `status`)
VALUES (1010010101, 'Jhon Doe', '1990-11-05', CURRENT_TIMESTAMP(), 1);
/* Mostrar solo la fecha del campo up */
SELECT username, DATE_FORMAT(birthday, '%W %M %Y') as birthday,
DATE(up) as up FROM users;
DATEDIFF
La función DATEDIFF()
en MySQL se utiliza para calcular la diferencia en días entre dos fechas, devuelve el valor entero que indica el número de días entre dos fechas, donde el primer argumento es la fecha de inicio y el segundo argumento es la fecha de finalización.
Ejemplo de uso
- Calcular el número de días entre el 1 de enero de 2023 y el 5 de diciembre de 2023:
1
SELECT DATEDIFF('2024-12-05', '2024-01-01'); /* 339 */
Esta sentencia retornará el número 339 que es la diferencia entre las dos fechas indicadas.
La función no tiene en cuenta la hora, minutos o segundos, solo las fechas. Si alguna de las fechas es
NULL
, el resultado seráNULL
.
- Filtrar registros basados en la diferencia de fechas
Si tenemos una tabla con registros de usuarios y sus fechas de inscripción, y queremos obtener solo los usuarios que se registraron hace más de 30 días:
1
2
SELECT * FROM usuarios
WHERE DATEDIFF(NOW(), fecha_inscripcion) > 30;
Esta sentencia devolverá todos los usuarios donde la columna fecha_inscripcion
es anterior a hace más de 30 días respecto a la fecha actual.
DATE_FORMAT
DATE_FORMAT()
solo cambia la forma en que se muestra la fecha, no altera el valor subyacente a la fecha en la base de datos.
Ejemplos de uso
- Formatear una fecha en formato
DD/MM/YYYY
:
1
SELECT DATE_FORMAT('2024-11-07', '%d/%m/%Y');
- Obtener el nombre del mes y del día:
1
SELECT DATE_FORMAT('2024-11-07', '%W, %M %d, %Y');
EXTRACT
La función EXTRACT()
utiliza los mismos argumentos que la función DATE_ADD()
o DATE_SUB()
, pero extrae partes de la fecha en lugar de realizar operaciones ariméticas de fechas.
Sintaxis de EXTRACT()
1
EXTRACT(unidad FROM fecha)
- unidad: El tipo de unidad, como
DAY
,MONTH
,YEAR
,HOUR
,MINUTE
,SECOND
, entre otros. - fecha: La fecha a la que le vamos extraer la unidad especificada.
Ejemplos
1
2
3
SELECT EXTRACT(YEAR FROM '2022-03-02');
SELECT EXTRACT(MONTH FROM CURDATE());
SELECT EXTRACT(MINUTE FROM CURDATE());
GET_FORMAT
Devuelve una cadena de formato. Esta función GET_FORMART()
es útil en combinación con DATE_FORMAT()
y STR_TO_DATE()
. Los valores posibles para el primer argumento dan como resultado varias cadenas de formato posibles.
Tabla de especificadores
Llamada de función | Resultado | Ejemplo |
---|---|---|
GET_FORMAT(DATE, 'USA') | '%m.%d.%Y' | '12.30.2021' |
GET_FORMAT(DATE, 'JIS') | '%Y-%m-%d' | '2021-12-30' |
GET_FORMAT(DATE, 'ISO') | '%Y-%m-%d' | '2021-12-30' |
GET_FORMAT(DATE, 'EUR') | '%d.%m.%Y' | '30.12.2021' |
GET_FORMAT(DATE, 'INTERNAL') | %Y%m%d' | 20211230 |
GET_FORMAT(DATETIME, 'USA') | '%Y-%m-%d %H.%i.%s' | '2021-12-30 07.45.14' |
GET_FORMAT(DATETIME, 'JIS') | '%Y-%m-%d %H:%i:%s' | 2021-12-30 07:45:14 |
GET_FORMAT(DATETIME, 'ISO') | '%Y-%m-%d %H:%i:%s' | 2021-12-30 07:45:14 |
GET_FORMAT(DATETIME, 'EUR') | '%Y-%m-%d %H.%i.%s' | 2021-12-30 07.45.14 |
GET_FORMAT(DATETIME, 'INTERNAL') | '%Y%m%d%H%i%s' | 20211230074514 |
Ejercicios Prácticos
Buscar registros entre dos fechas
Supongamos que tenemos una tabla eventos
con una columna fecha_evento
de tipo DATE
y queremos obtener todos los eventos que ocurren entre dos fechas específicas. Podemos usar la cláusula BETWEEN
para realizar la consulta:
1
2
SELECT * FROM eventos
WHERE fecha_evento BETWEEN '2023-01-01' AND '2023-12-31';
Esta sentencia devolverá todos los eventos donde la columna fecha_evento
esté dentro del rango 1 de enero del 2023 al 31 de diciembre de 2023.
La cláusula
BETWEEN
es inclusiva, lo que significa que las fechas inicial y final también se incluyen en el resultado.
Buscar registros después de una fecha específica
Si solo quisieramos obtener los eventos que ocurren después de una fecha específica, podemos usar el operador mayor que (>
):
1
2
SELECT * FROM eventos
WHERE fecha_evento > '2023-06-01';
Esta sentencia te devolverá todos los eventos que ocurren después del 1 de junio de 2023.
Buscar registros anteriores a una fecha específica
De manera similar al ejercicio anterior, podemos buscar los eventos que ocurren antes de una fecha específica usando el operador de menor que (<
):
1
2
SELECT * FROM eventos
WHERE fecha_evento < '2023-06-01';
Esta sentencia devolverá todos los eventos que ocurren antes del 1 de junio del 2023.
Filtrar eventos del mes actual
Si queremos obtener todos los eventos que ocurren en el mes actual, podemos usar la función MONTH()
y YEAR()
para extraer el mes y el año de la fecha:
1
2
3
SELECT * FROM eventos
WHERE MONTH(fecha_evento) = MONTH(CURDATE())
AND YEAR(fecha_evento) = YEAR(CURDATE());
Esta sentencia te devuelve todos los eventos donde la columna fecha_evento
corresponda al mes y año actual.
Notas Finales
Estos ejercicios prácticos nos ayudan a familiarizarnos con las funciones y operadores relacionados con fechas en MySQL. Desde realizar búsquedas entre fechas hasta trabajar con funciones de manipulación de fechas, estas habilidades son esenciales para cualquiera que trabaje con datos temporales en bases de datos.
Mi lema es