【问题标题】:Code for getting difference between two timestamp variables in hours以小时为单位获取两个时间戳变量之间差异的代码
【发布时间】:2015-08-27 18:56:52
【问题描述】:

我试图在我的数据库中使用我的 Duration 来自动获取我的代码中两个时间戳(LeaveFrom 和 Leaveto)之间的差异,这两个时间戳在我的代码中采用不同的格式。我有两个间隔的 Post 变量,以便第一个以 sql 格式显示日期,另一个以 sql 格式显示时间。它可以在我的数据库中显示为 Leaveto 和 LeaveFrom 的时间戳。我希望持续时间变量以小时为单位计算 $begindate 和 $enddate 之间的差异,同时将它与其他变量一起插入数据库。这可能吗?谁能解释一下?

if(isset($_POST['LeaveRequest'])) { // checking that form is submitted

    session_start();  //creating variables for form entries
    $Enum = $_POST['Employeenumber'];
    $fullname = $_POST['Leavename'];
    $leavetype = $_POST['Leavetype'];
    $begindate = $_POST['LeaveFrom'].' '.$_POST['BeginTime'];
    $enddate = $_POST['Leaveto'].' '.$_POST['EndTime'];
    $duration = (I dont know!!)
    $unit = $_POST['Unit'];
    $leavereason = $_POST['LeaveReason'];
    $leavestatus = "Pending";
    $supervisor = $_POST['Supervisor'];

$sql = $con->query("INSERT INTO Leave_details 
(Employeenumber, Leavename, Leavetype, LeaveFrom, Leaveto, 
Duration, Unitpick, LeaveReason, LeaveStatus,  Supervisor)Values('{$Enum}', 
'{$fullname}', '{$leavetype}', '{$begindate}', '{$enddate}' ,'{$duration}',
'{$unit}' , '{$leavereason}', '{$leavestatus}', '{$supervisor}')");


     header('Location: Account.php');

【问题讨论】:

标签: php mysql forms datetime time


【解决方案1】:

您可以使用DateTime

(如果您使用日期格式Y-m-d H:i:s 或类似)

$begindate = new DateTime($_POST['LeaveFrom'].' '.$_POST['BeginTime']);
$enddate = new DateTime($_POST['Leaveto'].' '.$_POST['EndTime']);
$diff = $begindate->diff($enddate);
print_r($diff);

输出:

DateInterval Object
(
    [y] => 0
    [m] => 0
    [d] => 1
    [h] => 0
    [i] => 0
    [s] => 0
    [invert] => 1
    [days] => 1
)

所以你可以使用:

$diff->h

希望这会有所帮助。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-07-21
    • 1970-01-01
    • 2021-01-04
    • 1970-01-01
    • 2021-05-14
    • 2020-06-08
    • 1970-01-01
    • 2014-02-26
    相关资源
    最近更新 更多