Foros del Web » Programando para Internet » PHP »

Fecha PHP y SQL Server

Estas en el tema de Fecha PHP y SQL Server en el foro de PHP en Foros del Web. Hola estoy trabajando con SQL server y PHP, y tengo una tabla donde uno de los campos es timedate. (01/03/2008 12:00:00 a.m.).... La tabla tiene ...
  #1 (permalink)  
Antiguo 13/05/2008, 18:34
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 9 meses
Puntos: 2
Exclamación Fecha PHP y SQL Server

Hola estoy trabajando con SQL server y PHP, y tengo una tabla donde uno de los campos es timedate. (01/03/2008 12:00:00 a.m.)....

La tabla tiene cargado por ejemplo el siguiente registro...

000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 08:00:00.000 Ingreso
000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 10:00:00.000 Egreso
000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 11:10:55.000 Ingreso
000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 13:00:00.000 Egreso
000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 14:00:00.000 Ingreso
000031319385 CLAUDIO ADRIAN, MARRERO 2008-03-01 20:10:55.000 Egreso

Yo necesito saber cuanto tiempo permanecio adentro... es decir, cuanto tiempo paso entre el primer ingreso el ultimo ingreso del dia. pero tengo que descontarle el tiempo que paso afuera....

Esto es para un sistema que estoy armando de control de personal, necesito saber la cantidad horas trabajadas al mes.

Entonces tengo en una base de datos todos los registros de ingreso y egreso.. y necesito a fin de mes, contabilizar cuantas horas trabajo el usuario...

Como puedo sumar estas horas...

Gracias
  #2 (permalink)  
Antiguo 14/05/2008, 05:51
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 9 meses
Puntos: 2
Re: Fecha PHP y SQL Server

El concepto creo que seria tomar el primer ingreso del dia, y sumarlo con el primer egreso, luego sumar el primer egreso con el segundo ingreso, luego el sengudo ingreso con el sugundo egreso y asi sucesivamente dia a dia..

Algo asi, pero como hago la suma para que me controle que no me sume las horas cuando sale.. solo las que estubo dentro..
Código PHP:
function horas($t1$t2) {
// calcula la diferencia en horas entre dos marcas de tiempo (aaaa-mm-dd hh:mm:ss)
// t1 - marca inicial, t2 - marca final
// primero calculamos la diferencia en días
$fecha1 explode(" "$t1);
$fecha2 explode(" "$t2);

$fecha_inicial $fecha1[0];
$fecha_final $fecha2[0];
$s = (strtotime($fecha_final) - strtotime($fecha_inicial)) / 86400;

// ahora la diferencia en horas
$tiempo_inicial explode(":"$fecha1[1]);
$tiempo_final explode(":"$fecha2[1]);
$hora_final $tiempo_final[0];
$hora_inicial $tiempo_inicial[0];

// Se resta uno si tenemos menos de 24 horas de diferencia
if($hora_final >= $hora_inicial) {
$h $hora_final $hora_inicial;
} else {
$h = (24 $hora_inicial) + $hora_final;
$s $s 1;
}

$t 24 $s $h;
return 
$t;


Última edición por cmarrero; 14/05/2008 a las 06:06
  #3 (permalink)  
Antiguo 14/05/2008, 10:03
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 9 meses
Puntos: 2
Exclamación Re: Fecha PHP y SQL Server

a ver...

hice lo siguiente: pero no me suma los minutos...

Archivo de funcion:

Código PHP:
function horas($t1$t2) {

$fecha1 explode(" "$t1);
$fecha2 explode(" "$t2);

$fecha_inicial $fecha1[0];
$fecha_final $fecha2[0];
$s = (strtotime($fecha_final) - strtotime($fecha_inicial)) / 86400;


$tiempo_inicial explode(":"$fecha1[1]);
$tiempo_final explode(":"$fecha2[1]);
$hora_final $tiempo_final[0];
$hora_inicial $tiempo_inicial[0];


if(
$hora_final >= $hora_inicial) {
$h $hora_final $hora_inicial;
} else {
$h = (24 $hora_inicial) + $hora_final;
$s $s 1;
}

$t 24 $s $h;
return 
$t;



Archivo donde muestro y sumo las horas:

Código PHP:
include("control_tiempo.php");
$suma=0;
$t1=0;
$t2=0;
    while (
$row=odbc_fetch_array($date)) {
        
        if (
$row["TYPE"]==1) {
            
$t1=$row["ACCESS_DATE"];
            
        } elseif (
$row["TYPE"]==2) {
        
                if (
$t1!=0) {
                
                    
$t2=$row["ACCESS_DATE"];
                    
$suma+=horas($t1,$t2);
                    
$t1=0;
                }
        }
            
            
    }
echo 
$suma

Esto me muestra lo siguiente:
CLAUDIO ADRIAN, MARRERO 10

El tema es que si lo vemos bien, lo unico que me suma son las horas, pero no me tiene en cuenta los minutos y segundos...

COMO MODIFICO ESTO, PARA QUE ME TENGA EN CUENTA LOS MINUTOS Y SEGUNDOS TAMBIEN...

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 14:07.