Ver Mensaje Individual
  #2 (permalink)  
Antiguo 03/10/2012, 13:19
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, 5 meses
Puntos: 2658
Respuesta: considerar dias entre rango de fechas

El secreto está en cómo realices la comparación de las alternativas que deben cumplirse y simplificarlas.
Hay varias condiciones:
- Empieza y termina dentro del período.
- Empieza durante y termina después.
- Empieza antes y termina durante.
- Empieza antes y termina después (contiene al periodo).
Las tres primeras tienen una singularidad: Al menos una de las fechas cae dentro del período, y si lo piensas, con sólo determinar eso, alcanza.
La última es necesaria porque no está comprendido en ninguno de los casos anteriores.
Entonces, la cosa sería mas o menos:
Código MySQL:
Ver original
  1. SELECT Fun_Codigo, fecha_inicio, fecha_termino
  2. FROM feriados_permisos
  3.     ((fecha_inicio BETWEEN '$fecha1' AND '$fecha2')
  4.     OR
  5.     (fecha_termino BETWEEN '$fecha1' AND '$fecha2')
  6.     OR
  7.     (fecha_inicio < '$fecha1' AND fecha_termino > '$fecha2'))
  8.     AND Fun_Codigo='$codigo'
  9. GROUP BY fecha_inicio
__________________
¿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; 03/10/2012 a las 14:10