一尘不染

在PHP中获得两次之间的时差

mysql

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

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

一次是恒定的,即,09:00:59另一次是我从数据库表中获得的。需要两者之间的差异。我正在使用PHP。希望我的问题清楚。

先感谢您。


阅读 205

收藏
2020-05-17

共1个答案

一尘不染

您可以使用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!';

演示版

查看已经提出的问题- 如何以分钟为单位获取时差:

从过去的一减去最近的一并除以60。

时间以Unix格式完成,因此它们只是一个很大的数字,显示了格林尼治标准时间1970年1月1日00:00:00起的秒数

2020-05-17