在PHP中获取两次时间差

时间:2012-12-18 07:09:39

标签: php mysql time

  

可能重复:
  How to get time difference in minutes in PHP

我正在出勤表上计算已故员工和已故员工。 我将登录时间存储在表中(类型:时间)。我能够从数据库中获取时间,我想在单独的列中显示时差。

即,如果员工登录或09:00:59之前,则其正确的时间和时间差异应显示为空。如果他在时间之后登录,即09:01:00或更晚,时差应为00:00:01。同样明智的我需要及时计算差异。

一次是常数,即09:00:59,另一个是我从数据库表中得到的。需要在两者之间获得差异。 我在PHP工作。 希望我的问题很明确。

先谢谢你。

3 个答案:

答案 0 :(得分:25)

您可以使用strtotime()进行时间计算。这是一个例子:

$checkTime = strtotime('09:00:59');
echo 'Check Time : '.date('H:i:s', $checkTime);
echo '<hr>';

$loginTime = strtotime('09:01:00');
$diff = $checkTime - $loginTime;
echo 'Login Time : '.date('H:i:s', $loginTime).'<br>';
echo ($diff < 0)? 'Late!' : 'Right time!'; echo '<br>';
echo 'Time diff in sec: '.abs($diff);

echo '<hr>';

$loginTime = strtotime('09:00:59');
$diff = $checkTime - $loginTime;
echo 'Login Time : '.date('H:i:s', $loginTime).'<br>';
echo ($diff < 0)? 'Late!' : 'Right time!';

echo '<hr>';

$loginTime = strtotime('09:00:00');
$diff = $checkTime - $loginTime;
echo 'Login Time : '.date('H:i:s', $loginTime).'<br>';
echo ($diff < 0)? 'Late!' : 'Right time!';

Demo

检查已提问的问题 - how to get time difference in minutes

  

从过去最多的一个减去过去最多的一个并除以60.

     

时间是以unix格式完成的,所以他们只是一个大数字显示   从1970年1月1日00:00:00 GMT起的秒数

答案 1 :(得分:14)

您也可以使用DateTime class:

$time1 = new DateTime('09:00:59');
$time2 = new DateTime('09:01:00');
$interval = $time1->diff($time2);
echo $interval->format('%s second(s)');

结果:

1 second(s)

答案 2 :(得分:-1)

<?php
$start = strtotime("12:00");
$end = // Run query to get datetime value from db
$elapsed = $end - $start;
echo date("H:i", $elapsed);
?>