Sumar y restar fechas con MySQL

Posiblemente en más de una ocasión habréis tenido que hacer consultas del estilo: “Contratos que vencen el mes que viene”, “Usuarios dados de baja el último mes”, “Noticias publicadas los últimos 10 días”… o similares para las que sueles necesitar realizar operaciones simples entre fechas.

Esta entrada es un pequeño recordatorio de las siguientes funciones de MySQL:

  • CURDATE(): Que nos devuelve la fecha actual.
  • DATE_ADD() y DATE_SUB(): Para sumar y restar fechas respectivamente.

Gracias a ellas podemos hacer consultas similares a las anteriores de forma directa. Veamos algunos ejemplos:
Contratos que terminan dentro de un mes

SELECT *
FROM contratos
WHERE finalizacion >= CURDATE()
AND finalizacion <= DATE_ADD(CURDATE(), INTERVAL 30 DAY)

Contratos que terminaron la última semana:

SELECT *
FROM contratos
WHERE finalizacion <= CURDATE()
AND finalizacion >= DATE_SUB(CURDATE(), INTERVAL 1 WEEK)

Hay muchas más funciones relacionadas con el tiempo y las fechas que os pueden sacar de un apuro y simplificaros mucho la vida. Os recuerdo que suele ser mucho mejor hacer una buena consulta que tratar posteriormente los datos que nos devuelve con la siguiente capa de nuestra aplicación. Tenéis la referencia en la web oficial de MySQL.

Entradas relacionadas:

  1. Comparar fechas en formato MySQL con PHP
  2. Hacer copia de seguridad e importar una Base de Datos MySQL
  3. Instalar MySQL Server en Ubuntu
  4. Resetear autoincremento en MySQL
  5. Instalar el conector de MySQL sobre Mono

Acerca de F. Javier Carazo Gil

Casi Ingeniero Informático, co-fundador y administrador de Linux Hispano, co-fundador de Red de Autores y Geometrio, puedes saber más sobre mí, mi vida laboral, mis libros, mis artículos y mi día a día en @fjcarazo y en mi perfil público de LinkedIn.
  • http://www.nacho-lopez.com/ Nacho López

    La manipulación de las fechas en SQL siempre ha sido mi punto débil. No sabía el comando INTERVALE que aparecen los ejemplos.

    Muy buena Carazo, gracias por el aporte.

  • Pingback: Tweets that mention Suma y resta de fechas con MySQL | Linux Hispano -- Topsy.com

  • http://www.jcarazo.com carazo

    @Nacho: Me alegro que te sea útil, este tipo de funciones como digo aligeran no sólo la complejidad sino el tiempo de ejecución, que siempre es algo esencial en aplicaciones que interactúan contra servidores.

  • AngelFQC

    Excelente post
    justo necesitaba para listar las ventas de la ultima semana en trabajo de la universidad
    gracias!!!

  • http://www.piscinas.cl Ricardo Alvarez

    Excelente funcion muchachos..se agradece el tiempo que nos ahorran. saludos.

  • Dennry

    Viejito, se te agradece me has salvado la vida, tenia que culminar una sistemilla para este mes, y por mas que intentaba ya no sabia que mas hacer, y tu sabes que te puede caer tu demanda por incumplimiento de contrato, en verdad hermano me salvaste. Muchas gracias y suerte!

  • http://www.jcarazo.com carazo

    @Denry: Me alegro que te haya ayudado. Como siempre digo, si queréis más información de cualquier tipo sobre cualquier tema, sólo tenéis que comentarlo.

  • Icaro

    Gracias!!! Me ha sido muy util el post… Saludos!!!!