使用从 MySQL TIME 字段中检索到的值计算时差
Calculating time difference with values retrieved from MySQL TIME field
我做了一些搜索,有很多关于使用 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_time
和 finish_time
在 MySQL 和 total_breaks
中存储为 TIME
值,作为 INT
我可能应该将其转换为TIME
值,并表示为 00:30:00
或 00:00:00
以保持一致性。
我想做的是显示一个 table 来显示所有这些信息,以及他们的总工作时数,然后是总时数减去任何休息时间。
我已经能够使用 staff_id
、day
、start_time
和 finish_time
生成 table,但我正在努力找出计算总工作时间等的最佳方法
我正在使用 Laravel,我读到 strtotime('00:00:00')
是一个很好的方法,但这不会起作用,因为我没有使用字符串,而是在拖时间来自数据库。
计算两次时间差的最佳方法是什么,然后再考虑休息时间。
我设置正确了吗?我不想将时间设置为 DATETIME,因为我只是想计算他们每周正常工作时间的时差 - 尽管我总是可以在必要时使用虚拟日期来完成这项工作.
有什么想法吗?
不确定你问题中的一些事情,所以我将从一个查询开始,我们可以在继续进行时增加这里的内容。
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'));
没必要把事情弄得太复杂。
您始终可以使用 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>';
?>
clocked in: 2015-09-23 22:00:00
clocked out: 2015-09-24 06:00:00
breaks: 30 minutes
hours worked: 7.50
建议:将您的 start_time
和 finish_time
字段更改为 DATETIME
这样即使有人工作到半夜也不会有问题到第二天,就像我使用的代码一样。
注意: 如果您使用 strtotime
而没有指定日期,例如 strtotime(09:00:00)
... 当前日期将自动添加以形成完整的 DateTime
。 但是如果有人工作到午夜,计算结果将是负数。
IF 没有人工作到午夜,您可以像这样使用 Time
作为您的数据...
<?php
$start_time = '09:00:00';
$finish_time = '17:00:00';
$starttime = strtotime($start_time);
$endtime = strtotime($finish_time);
etc...
?>
我做了一些搜索,有很多关于使用 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_time
和 finish_time
在 MySQL 和 total_breaks
中存储为 TIME
值,作为 INT
我可能应该将其转换为TIME
值,并表示为 00:30:00
或 00:00:00
以保持一致性。
我想做的是显示一个 table 来显示所有这些信息,以及他们的总工作时数,然后是总时数减去任何休息时间。
我已经能够使用 staff_id
、day
、start_time
和 finish_time
生成 table,但我正在努力找出计算总工作时间等的最佳方法
我正在使用 Laravel,我读到 strtotime('00:00:00')
是一个很好的方法,但这不会起作用,因为我没有使用字符串,而是在拖时间来自数据库。
计算两次时间差的最佳方法是什么,然后再考虑休息时间。
我设置正确了吗?我不想将时间设置为 DATETIME,因为我只是想计算他们每周正常工作时间的时差 - 尽管我总是可以在必要时使用虚拟日期来完成这项工作.
有什么想法吗?
不确定你问题中的一些事情,所以我将从一个查询开始,我们可以在继续进行时增加这里的内容。
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'));
没必要把事情弄得太复杂。
您始终可以使用 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>';
?>
clocked in: 2015-09-23 22:00:00
clocked out: 2015-09-24 06:00:00
breaks: 30 minutes
hours worked: 7.50
建议:将您的 start_time
和 finish_time
字段更改为 DATETIME
这样即使有人工作到半夜也不会有问题到第二天,就像我使用的代码一样。
注意: 如果您使用 strtotime
而没有指定日期,例如 strtotime(09:00:00)
... 当前日期将自动添加以形成完整的 DateTime
。 但是如果有人工作到午夜,计算结果将是负数。
IF 没有人工作到午夜,您可以像这样使用 Time
作为您的数据...
<?php
$start_time = '09:00:00';
$finish_time = '17:00:00';
$starttime = strtotime($start_time);
$endtime = strtotime($finish_time);
etc...
?>