使用从MySQL TIME字段

时间:2015-09-24 04:04:51

标签: php mysql datetime laravel laravel-5.1

我已经做了一些搜索,有很多关于使用strtotime('09:00:00)计算两次之间的时差,然后将其与另一个值相对应的信息。

目前,我有一个数据库,可以为员工安排正常工作时间:

+----------+-----------+------------+-------------+--------------+
| staff_id |    day    | start_time | finish_time | total_breaks |
+----------+-----------+------------+-------------+--------------+
|        1 | Monday    | 18:00:00   | 22:00:00    |            0 |
|        2 | Wednesday | 09:00:00   | 17:30:00    |           30 |
+----------+-----------+------------+-------------+--------------+

start_timefinish_time在MySQL中存储为TIME值,在total_breaks中存储为INT,我应该将其转换为TIME值同样也代表00:30:0000:00:00以保持一致性。

我希望能够做的是显示一个表格,显示所有这些信息,以及他们的总工作时间,然后总小时减去任何休息时间。

我已经能够使用staff_iddaystart_timefinish_time生成一个表格,但我正在努力找出计算总数的最佳方法工作时间等。

我正在使用Laravel,并且已经读过strtotime('00:00:00')这是一个很好的方法,但这不起作用,因为我没有使用字符串,而是从数据库中抽出时间。

计算两次时间差的最佳方法是什么,然后考虑休息时间。

我是否正确设置了这个?我不想将时间设置为DATETIME,因为我只是想计算他们每周做的正常工作时间的时差 - 虽然我总是可以使用虚拟日期来帮助它在必要时工作

有什么想法吗?

2 个答案:

答案 0 :(得分:1)

不需要让事情变得过于复杂。

您始终可以使用strtotime

将数据库时间转换为纪元时间
<?php
$start_time = '2015-09-23 22:00:00'; // pulled from DB
$finish_time = '2015-09-24 06:00:00'; // pulled from DB
$starttime = strtotime($start_time); // convert to timestring
$endtime = strtotime($finish_time); // convert to timestring
$diff = $endtime - $starttime; // do the math

$total_breaks = 30; // pulled from DB
$breaks = $total_breaks*60; // minutes * seconds per minute
$hours = ($diff - $breaks)/60/60; // do the math converting seconds to hours
?>

上面的代码会像这样输出......

<?php
echo 'clocked in: '.$start_time.'<br>';
echo 'clocked out: '.$finish_time.'<br>';
echo 'breaks: '.$total_breaks.' minutes<br>';
echo 'hours worked: '.number_format($hours, 2).'<br>';
?>
  时间:2015-09-23 22:00:00
  时钟:2015-09-24 06:00:00
  休息时间:30分钟   工作时间:7.50

建议:将您的start_timefinish_time字段更改为DATETIME,这样如果有人在午夜到第二天工作,就不会有问题在我使用的代码中。

快乐的编码!

注意:如果您使用的strtotime没有指定strtotime(09:00:00)之类的日期...系统会自动添加当前日期以形成完整的DateTime但是如果有人在午夜工作,计算将产生负数。

如果没有人在午夜工作,您可以使用Time作为您的数据,如此...

<?php
$start_time = '09:00:00';
$finish_time = '17:00:00';
$starttime = strtotime($start_time);
$endtime = strtotime($finish_time);
etc...
?>

答案 1 :(得分:0)

不确定您的问题中的一些内容,因此我将从查询开始,随着时间的推移,我们可以在此处增加最新信息。

mysql> SELECT TIMEDIFF( '09:00:00', '17:30:00' );
+------------------------------------+
| TIMEDIFF( '09:00:00', '17:30:00' ) |
+------------------------------------+
| -08:30:00                          |
+------------------------------------+
1 row in set (0.00 sec)

你可以用它来计算从开始到结束的总时间...... TIMEDIFF( start_time, finish_time ) AS total_time

然后,我们需要从该值中扣除总分钟数。

一旦我们知道休息了多少分钟......

mysql> select ADDTIME('08:00:00', '00:30:00');
+---------------------------------+
| ADDTIME('08:00:00', '00:30:00') |
+---------------------------------+
| 08:30:00                        |
+---------------------------------+
1 row in set (0.00 sec)

看起来如何?

好的,所以在PHP中进行类似的计算很容易。

$start_time = new DateTime($your_start_time);
$finish_time = new DateTime($your_finish_time);
$diff = $start_time->Diff($finish_time);
$hours = $diff->format("%H");

此外,当你有finish_time时。您可以从中删除时间(基于休息时间)(30分钟为30分钟);

$finish_time->sub(new DateInterval('PT30M'));