Foros del Web » Programando para Internet » PHP »

Restar horas

Estas en el tema de Restar horas en el foro de PHP en Foros del Web. Hola, quería saber como puedo hacer para restar dos tipo date de nua base de datos. La idea, es evitar que un usuario pueda enviar ...
  #1 (permalink)  
Antiguo 19/09/2005, 07:00
 
Fecha de Ingreso: septiembre-2005
Mensajes: 3
Antigüedad: 18 años, 7 meses
Puntos: 0
Restar horas

Hola, quería saber como puedo hacer para restar dos tipo date de nua base de datos. La idea, es evitar que un usuario pueda enviar dos mensajes en menos de un minuto en un foro, pero al restar dos horas (tipos de dato date de mi base de datos), no consigo que haga bien la resta.

A ver si alguien puede echarme una mano

salu2
  #2 (permalink)  
Antiguo 19/09/2005, 07:18
Avatar de jerkan  
Fecha de Ingreso: septiembre-2005
Mensajes: 1.607
Antigüedad: 18 años, 7 meses
Puntos: 19
Pues no se si el php tiene alguna funcion que haga eso pero yo me hice una. Aquí está:
Código PHP:
/**
* Compara dos fechas.
*
* Devuelve -1 si la primera fecha(fecha1, hora1) es menor que la segunda(fecha2, hora2) 
* Devuelve 0 si la primera fecha(fecha1, hora1) es igual que la segunda(fecha2, hora2)
* Devuelve 1 si la primera fecha(fecha1, hora1) es mayor que la segunda(fecha2, hora2)
*/    
function compareDates($fecha1$hora1$fecha2$hora2)
{
    
$resultado 0;
         
     
//echo "<BR>PreFecha1: ".$fecha1." PreFecha2: ".$fecha2;
         
     // gestiona la primera fecha
     
$trozos=explode(SEPARADOR_FECHA,$fecha1,3);
     
$Fecha1Dia $trozos[0];
     
$Fecha1Mes $trozos[1];
     
$Fecha1Ano $trozos[2];

    
//echo "<BR>PostFecha 1: ".$Fecha1Dia."-".$Fecha1Mes."-".$Fecha1Ano;
                         
     // gestiona la primera hora
    
$trozos=explode(":",$hora1,3);
     
$Hora1Hora $trozos[0];
     
$Hora1Minuto $trozos[1];
     
$Hora1Segundo $trozos[2];
         
     
//echo "<BR>PostHora 1: ".$Hora1Hora.":".$Hora1Minuto.":".$Hora1Segundo;
        
     // Gestiona la segunda fecha
     
$trozos=explode(SEPARADOR_FECHA,$fecha2,3);
     
$Fecha2Dia $trozos[0];
     
$Fecha2Mes $trozos[1];
     
$Fecha2Ano $trozos[2];

    
//echo "<BR>PostFecha 2: ".$Fecha2Dia."-".$Fecha2Mes."-".$Fecha2Ano;
        
     // gestiona la segunda hora
    
$trozos=explode(":",$hora2,3);
     
$Hora2Hora $trozos[0];
     
$Hora2Minuto $trozos[1];
     
$Hora2Segundo $trozos[2];
         
    
//echo "<BR>PostHora 2: ".$Hora2Hora.":".$Hora2Minuto.":".$Hora2Segundo;
                 
     // Compara la fechas
    
if( ( $Fecha1Ano $Fecha2Ano )
     || ( 
$Fecha1Ano == $Fecha2Ano && $Fecha1Mes $Fecha2Mes )
     || ( 
$Fecha1Ano == $Fecha2Ano && $Fecha1Mes == $Fecha2Mes && $Fecha1Dia $Fecha2Dia) )
    {
        
$resultado = -1;
    }    
        
    if( (
$Fecha1Ano == $Fecha2Ano
     && (
$Fecha1Mes == $Fecha2Mes)
     && (
$Fecha1Dia == $Fecha2Dia ) )
    {
        if( (
$Hora1Hora $Hora2Hora)
        || (
$Hora1Hora == $Hora2Hora && $Hora1Minuto $Hora2Minuto )
        || (
$Hora1Hora == $Hora2Hora && $Hora1Minuto == $Hora2Minuto && $Hora1Segundo $Hora2Segundo) )
        {
            
$resultado = -1;
        }
        else if( (
$Hora1Hora == $Hora2Hora)
        &&  (
$Hora1Minuto == $Hora2Minuto)
        &&  (
$Hora1Segundo == $Hora2Segundo) )
            {
                
$resultado 0;
            }
            else
            {
                
$resultado 1;
            }
        }
                
    if( ( 
$Fecha1Ano $Fecha2Ano )
    || ( 
$Fecha1Ano == $Fecha2Ano && $Fecha1Mes $Fecha2Mes )
    || ( 
$Fecha1Ano == $Fecha2Ano && $Fecha1Mes == $Fecha2Mes && $Fecha1Dia $Fecha2Dia) )
    {
        
$resultado 1;
    }    
                
     return 
$resultado;


Última edición por jerkan; 18/12/2005 a las 09:49
  #3 (permalink)  
Antiguo 19/09/2005, 08:53
 
Fecha de Ingreso: septiembre-2005
Mensajes: 3
Antigüedad: 18 años, 7 meses
Puntos: 0
Muchas gracias!!!

Por lo que veo, esa función mira si las dos fechas son mayores, iguales o menores, y a mi me interesaría que entre una y otra, no hubiera menos de un minuto.

Voy a ver si sobre lo tuyo puedo cambiarlo.

gracias
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:36.