bases de datos

Calcular diferencia entre dos fechas con MySQL

Introducción

Hoy me vi en la necesidad de calcular el tiempo transcurrido entre dos fechas en el motor de base de datos MySQL.

El problema era calcular los años que han pasado desde una fecha hasta hoy.

Calcular diferencia entre dos fechas con MySQL

Para seleccionar la diferencia en años, meses, o días podemos utilizar timestampdiff. Es una función que toma 3 argumentos:

  • La forma en la que queremos obtener los resultados. Por ejemplo, meses, años o días
  • La fecha 1
  • La fecha 2

Veamos algunos ejemplos

Diferencia en años

Para saber cuántos años han pasado en MySQL podemos hacer esto:

SELECT TIMESTAMPDIFF(YEAR, '1997-06-21', '2018-05-07') AS años_transcurridos;

Eso daría un resultado de 20, como se puede ver a continuación:

Claro que también podemos aplicarlo a datos ya existentes. Por ejemplo, si deseara calcular la edad de algunos alumnos (a la fecha actual) de una base de datos sería así:

Recordemos que el tercer argumento (la fecha actual) puede ser pasado con un lenguaje de programación, o calculado con CURDATE. Si utilizamos CURDATE dependemos del servidor MySQL y si su zona horaria está mal, tendremos resultados inesperados.

En fin, si no nos importa, los resultados son los mismos:

Diferencia de fechas en meses

Para hacerlo con meses, es por ejemplo:

SELECT TIMESTAMPDIFF(MONTH, '1997-06-21', '2018-05-07') AS meses_transcurridos;

Si lo ejecuto:

Igualmente podemos calcularlo con columnas de una base de datos, como con el ejemplo de los años.

Diferencia de fechas en días

Lo mismo pero cambiamos sólo el primer argumento a DAY. Así:

SELECT TIMESTAMPDIFF(DAY, '1997-06-21', '2018-05-07') AS dias_transcurridos;

Con estos resultados:

Horas, minutos, segundos

Claro que es posible calcular las horas, minutos o segundos transcurridos. Sólo cambiamos el primer argumento a HOUR, MINUTE o SECOND.

Aquí unos ejemplos:

Así es como podemos calcular o sacar  la diferencia de 2 fechas en MySQL.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Ver comentarios

  • Hombre tu anti bloqueadores no jala, desactive mi adblock del chrome y aun asi me detecta tuve que eliminar la capa de anti adblock con las herramientas de desarrollador

Entradas recientes

Creador de credenciales web – Aplicación gratuita

Hoy te voy a presentar un creador de credenciales que acabo de programar y que…

1 semana hace

Desplegar PWA creada con Vue 3, Vite y SQLite3 en Apache

Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…

2 semanas hace

Arquitectura para wasm con Go, Vue 3, Pinia y Vite

En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…

2 semanas hace

Vue 3 y Vite: crear PWA (Progressive Web App)

En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…

2 semanas hace

Errores de Comlink y algunas soluciones

Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…

2 semanas hace

Esperar promesa para inicializar Store de Pinia con Vue 3

En este artículo te voy a enseñar cómo usar un "top level await" esperando a…

2 semanas hace

Esta web usa cookies.