Hola vani18:
Supongamos que tienes una tabla así:
Código MySQL:
Ver original+------+---------------------+
| id | fecha |
+------+---------------------+
| 1 | 2016-01-07 00:00:00 |
| 2 | 2016-01-07 12:21:25 |
| 3 | 2016-01-07 23:59:59 |
| 4 | 2016-01-05 23:59:59 |
| 5 | 2016-01-06 00:00:00 |
| 6 | 2016-01-08 00:00:00 |
+------+---------------------+
El problema en realidad se resume en comparar sólo la fecha sin considerar la hora... esto lo puedes hacer con la función DATE(), de tal suerte que puedes hacer algo como esto:
Código MySQL:
Ver original+------+---------------------+
| id | fecha |
+------+---------------------+
| 1 | 2016-01-07 00:00:00 |
| 2 | 2016-01-07 12:21:25 |
| 3 | 2016-01-07 23:59:59 |
+------+---------------------+
O mejor aun, utilizar la función CURDATE() para obtener la fecha actual (sin horas);
Código MySQL:
Ver original+------+---------------------+
| id | fecha |
+------+---------------------+
| 1 | 2016-01-07 00:00:00 |
| 2 | 2016-01-07 12:21:25 |
| 3 | 2016-01-07 23:59:59 |
+------+---------------------+
El resultado es el mismo que con la consulta que tú estás haciendo:
Código MySQL:
Ver original -> fecha
>= '2016-01-07 00:00:00' AND -> fecha <= '2016-01-07 23:59:59';
+------+---------------------+
| id | fecha |
+------+---------------------+
| 1 | 2016-01-07 00:00:00 |
| 2 | 2016-01-07 12:21:25 |
| 3 | 2016-01-07 23:59:59 |
+------+---------------------+
Finalmente una observación: no utilices nombres de campos que sean palabras reservadas: DATE_ADD es una función de MySQL, lo que puede ocasionarte problemas.
Haz la prueba y nos comentas.
Saludos
Leo.