Juan Santamaría

Juan Santamaría

Programador web

Seleccionar registros entre dos fechas con MySQL

Desde que empecé a trabajar con bases de datos y con programación en PHP algo a lo que siempre he tenido mucha tirria es al manejar de fechas. Con el paso del tiempo lógicamente te vas adaptando y lo que antes te costaba medio siglo ahora lo haces en un pis-pas.

Registros entre dos fechas con MySQL

En el artículo de hoy os voy a enseñar algo bastante simple pero muy útil para por ejemplo, sacar estadísticas de registros de usuarios o de ingresos de una plataforma online. Vamos a plantearnos que queremos sacar el número de usuarios registrados entre el 20 de Marzo de 2016 y el 31 de Mayo de 2016 y para ello vamos a hacer uso de la sentencia BETWEEN de MySQL:

SELECT * FROM `usuarios` WHERE fecha BETWEEN '2016-03-20' AND '2016-20-31'

Si os fijáis la consulta es bastante sencilla y lo único que tendrías que reemplazar es el nombre de la tabla y el campo donde guardamos la fecha (que podría ser reg_date, fecha_registro,etc) , además de las fechas entre las que queráis consultar siempre en el formato YYYY-MM-DD donde YYYY es el año MM el mes y DD el día.

Si quisiéramos sacar los registros de usuarios entre dos horas del día determinadas (si el campo fecha fuera un DATETIME lógicamente) solo tendríamos que modificar la consulta por:

SELECT * FROM `usuarios` WHERE fecha BETWEEN '2016-03-20 15:00:00' AND '2016-03-20 18:00:00'

La sentencia BETWEEN no solo es aplicable a fechas si no que la podréis aplicar a otro tipo de rangos por ejemplo entre dos números.

Espero que os sirva este pequeño tip el cual es bastante útil.

COMPARTE TU OPINIÓN

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

Uso de cookies

Este sitio web utiliza cookies para que usted tenga la mejor experiencia de usuario. Si continúa navegando está dando su consentimiento para la aceptación de las mencionadas cookies y la aceptación de nuestra política de cookies

ACEPTAR
Aviso de cookies