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:

See the gist on github.

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:

See the gist on github.

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

See the gist on github.

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.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

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

Compartir
Publicado por
parzibyte

Entradas recientes

Solución: Unable to extract uploader id con youtube-dl

En mi blog te he enseñado a usar youtube-dl para descargar vídeos con permiso del…

18 horas hace

Enviar foto a Telegram usando cURL y Bot

Siguiendo con los tutoriales que consumen la API de los Bots de Telegram con cURL…

19 horas hace

cURL y Telegram: enviar mensaje a Bot

En un post previo te enseñé a enviar un mensaje en nombre de un Bot…

22 horas hace

Impresora térmica con Telegram usando Bot

En este artículo te voy a mostrar una guía para imprimir en una impresora térmica…

1 día hace

Imprimir PDF con Bot de Telegram

La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…

5 días hace

Enviar mensaje con bot de Telegram usando JavaScript (lado del cliente)

Hoy te enseñaré cómo enviar un mensaje a un usuario desde un bot de Telegram…

6 días hace

Esta web usa cookies.