Ver Mensaje Individual
  #5 (permalink)  
Antiguo 17/04/2013, 11:51
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 16 años, 4 meses
Puntos: 2658
Respuesta: [Aporte] Hacer query por date en columna tipo datetime (indexada)

Es un problema de decisión de selección de índice que realiza el parser.
Cuando usas DATE() o STR_TO_DATE, en realidad estás convirtiendo algo que tiene el mismo formato de la clave de índice, por algo diferente. En ese caso no detecta igualdad y lo descarta (Oracle hace algo parecido en ciertos casos).
En cambio, cuando realizas la consulta así:
Código MySQL:
Ver original
  1. FROM tabla
  2. WHERE column_datetime BETWEEN "2013-04-01" AND "2013-04-10 23:59:59"
antes de verificar si el indice es aplicable tiene que realizar la conversión y en ese contexto, el dato es del mimo tipo y longitud... y el indice aplica.
Para estar más seguros, habría que probar qué pasa al usar:
Código MySQL:
Ver original
  1. FROM tabla
  2. WHERE column_datetime BETWEEN STR_TO_DATE('2013-04-01 00:00:00') AND STR_TO_DATE('2013-04-10 23:59:59);

Lo que sí es seguro es que al usar DATE_FORMAT() sobre el campo indexado, el índice se descarte, precisamente porque se pierde la relación entre el dato y el índice.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)

Última edición por gnzsoloyo; 17/04/2013 a las 11:57