Foros del Web » Programando para Internet » PHP »

duda para rangos de tiempo

Estas en el tema de duda para rangos de tiempo en el foro de PHP en Foros del Web. 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 ...
  #1 (permalink)  
Antiguo 08/04/2011, 17:55
 
Fecha de Ingreso: agosto-2009
Mensajes: 349
Antigüedad: 14 años, 8 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.
  #2 (permalink)  
Antiguo 08/04/2011, 18:45
Avatar de Ronruby  
Fecha de Ingreso: julio-2008
Ubicación: 18°30'N, 69°59'W
Mensajes: 4.879
Antigüedad: 15 años, 9 meses
Puntos: 416
Respuesta: duda para rangos de tiempo

Creo que tienes un problemita con el diseño de tu aplicacion en cuanto a la hora de los eventos, pero dejando eso de lado, no puedes comparar fechas directamente como lo estas haciendo. Tienes que usar timestamps. Lee sobre strtotime() o mktime()
O podrias hacer que MySQL lo maneje directamente ya que si permite ese tipo de comparaciones
  #3 (permalink)  
Antiguo 25/04/2011, 11:56
 
Fecha de Ingreso: agosto-2009
Mensajes: 349
Antigüedad: 14 años, 8 meses
Puntos: 8
Respuesta: duda para rangos de tiempo

Hola,

perdón por no responder antes pero la universidad no me dejó tiempo nisiquiera para disfrutar de la semana santa.

Estoy tomando en cuenta tu respuesta y ya tengo lo siguiente:

Código PHP:
Ver original
  1. <?php
  2.         $hora_actual1 = "14:30";
  3.         $ha = explode(":",$hora_actual1);
  4.         $hora_actual=mktime(0,0,$ha[1],$ha[0]);
  5.        
  6.         $hora_operar1 = "".$_POST['hh'].":".$_POST['mm']."";
  7.         $ho = explode(":",$hora_operar1);
  8.         $hora_operar=mktime(0,0,$ho[1],$ho[0]);
  9.        
  10.         echo "Hora operar: ".$hora_operar1."<br>Hora operar mktime: ".$hora_operar."<br><br>";
  11.        
  12.         echo "Hora actual: ".$hora_actual1."<br>Hora actual mktime: ".$hora_actual."<br><br>";
  13.        
  14.         echo "Diferencia: ".($hora_operar-$hora_actual)."<br><br>";
  15.        
  16.         if($hora_actual > $hora_operar) {
  17.             echo "hora actual es mayor que hora operar";
  18.         } else {
  19.             echo "hora actual es menor que hora operar";
  20.         }
  21.        
  22.     ?>

Aparentemente esta todo bien, la condicionante me muestra el texto correcto todo el tiempo. Ahora lo que debo hacer es averiguar cuál es el valor de una hora y media con esta función. Se me ocurrió imprimir los valores que obtengo.

Cuando selecciono como hora a trabajar 11:30...

Hora operar: 11:30
Hora operar mktime: 1322179230

Hora actual: 12:30
Hora actual mktime: 1324771230

Diferencia: -2592000

hora actual es mayor que hora operar


Cuando selecciono como hora a trabajar 13:30...

Hora operar: 13:30
Hora operar mktime: 1327449630

Hora actual: 12:30
Hora actual mktime: 1324771230

Diferencia: 2678400

hora actual es menor que hora operar


Como pueden ver, al restar los valores obtenidas con la función a pesar de tener una hora de diferencia el resultado es distinto. He probado con distintos horarios y aveces coincide la diferencia pero en otras ocaciones no. Quisiera saber cómo puedo realmente lograr verificar que la diferencia entre una y otra fecha es de una hora y media.

Gracias desde ya!

Etiquetas: rangos
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 19:22.