Ver Mensaje Individual
  #1 (permalink)  
Antiguo 08/04/2011, 17:55
kenproxd
 
Fecha de Ingreso: agosto-2009
Mensajes: 349
Antigüedad: 14 años, 9 meses
Puntos: 8
duda para rangos de tiempo

Hola a todos!

Tengo una pequeña complicación con un sistema que ando realizando. Sirve para que organizadores de actividades propongan eventos. Para esto deben llenar un formulario en el que se les pide la fecha y hora de dicho evento.

Mi intención es comprobar que el evento que proponen no se cruce con el de los demás organizadores. Para esto realicé lo siguiente:

Código PHP:
Ver original
  1. $coincidencia = '';
  2.  
  3. $coincide = mysql_query("SELECT hora FROM programados WHERE fecha = '$fecha' AND hora = '$hora'");
  4.  
  5. $num_coin = mysql_num_rows($coincide);
  6.            
  7. if($num_coin != '') {
  8. $coincidencia = 'coincide';
  9. }

Hasta ahi todo bien. Ahora necesito que, además de comprobar que no existan eventos programados para esa hora, compruebe que la hora que está proponiendo el organizador sea 2 horas antes o 1 hora y 30 minutos después de los eventos que ya han sido programados.

Entonces se me ocurre obtener las horas limite de la siguiente manera:

Código PHP:
Ver original
  1. $h1 = $_POST['hora']+1;
  2. $m1 = $_POST['minutos']+30;
  3. $hora_limite1 = "$h1:$m1:00";
  4.  
  5. $h2 = $_POST['hora']-2;
  6.  $m2 = $_POST['minutos'];
  7. $hora_limite2 = "$h2:$m2:00";

Y luego hacer un query para obtener los eventos programados para la fecha indicada. Finalmente usar un bucle y un condicionante, más o menos de esta forma:

Código PHP:
Ver original
  1. $query = mysql_query("SELECT hora FROM programados WHERE fecha = '$fecha'");
  2.  
  3. $a_coincide = 0;
  4.  
  5. while ($row = mysql_fetch_array($query)) {
  6.  
  7. if($row['hora'] < $hora_limite1 or $row['hora'] > $hora_limite2) {
  8. $a_coincide++;
  9. }
  10.  
  11. }
  12.  
  13. if($a_coincide != 0) {
  14. $coincidencia = 'coincide';
  15. }

El problema es que el IF que coloco dentro del bucle no funciona.

Alguien tiene una idea?

Gracias desde ya.