php - 使用从 MySQL TIME 字段检索的值计算时间差

标签 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,因为我只是想计算他们每周正常工作时间的时差 - 尽管我总是可以在必要时使用虚拟日期来完成这项工作.

有什么想法吗?

最佳答案

没必要把事情弄得太复杂。

您始终可以使用 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_timefinish_time 字段更改为DATETIME 这样您就不会遇到问题有人像我使用的代码一样工作到午夜到第二天。

注意:如果您使用 strtotime 而没有指定日期,例如 strtotime(09:00:00) ... 当前日期将自动添加以形成一个完整的 DateTime但是如果有人工作到午夜,计算结果将是负数。

如果没有人工作到午夜,您可以像这样使用时间作为您的数据...

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

关于php - 使用从 MySQL TIME 字段检索的值计算时间差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32753155/

相关文章:

mysql - Rails mysql : How to query tables with deeply nested relations(has_many and belongs_to)?

mysql - 当前日期类型转换

php - mysql计算两个数的区别

php - 如何获取mysql中的最后一个同类?

php - 使用 PHP PDO 时,我应该清理/过滤用户输入和输出吗?

c# - 在 .net Web 服务方法签名中使用 DateTime 或 String

java - 将十六进制值转换为时间戳/日期和时间

javascript - 应该得到 3 张图像的网格

php - 尝试访问我的数据库时访问被拒绝

mysql - Bash 检查 mysql 命令是否失败