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:

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:

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í:

Relacionado:  PHP: diferencia entre array_merge y array_merge_recursive

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 disponible para trabajar en tu proyecto o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.
Si el post fue de tu agrado muestra tu apoyo compartiéndolo, suscribiéndote al blog, siguiéndome o realizando una donación.

Suscribir por correo

Ingresa tu correo y recibirás mis últimas entradas sobre programación, open source, bases de datos y todo lo relacionado con informática

Únete a otros 577 suscriptores


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/

3 Comments

El HacKEr · octubre 21, 2019 a las 6:28 pm

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

    parzibyte · octubre 21, 2019 a las 7:55 pm

    Hola. Gracias por reportarlo, ya lo he arreglado.
    Saludos

Sumar y restar fechas con MySQL usando date_add y date_sub - Parzibyte's blog · diciembre 5, 2018 a las 2:05 pm

[…] vimos cómo calcular la diferencia de fechas en años, meses, o cualquier tipo de medida en MySQL. Ahora veamos cómo operar con fechas; es decir, sumar y restar tiempo a fechas con […]

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

A %d blogueros les gusta esto: