我想用日期添加hh:mm:ss.我该怎么做?
我试过以下但是当小时是字符串时它可以工作,但是当添加时间类似于MySQL日期时它不起作用.
$new_time = date("Y-m-d H:i:s",strtotime('+5 hours'));
我正在尝试获得以下解决方案:
$timeA= '2015-10-09 13:40:14';
$timeB = '03:05:01'; // '0000-00-00 03:05:01'
输出:
$timeA + $timeB = 2015-10-09 16:45:15 ?
我该如何添加?
最佳答案
使用
原文链接:https://www.f2er.com/mysql/433509.htmlDateInterval()
:
$timeA = new DateTime('2015-10-09 13:40:14');
$timeB = new DateInterval('PT3H5M1S'); // '03:05:01';
$timeA->add($timeB);
echo $timeA->format('Y-m-d H:i:s');
您需要将时间分解为正确的DateInterval格式,但这很容易使用explode();
这可能是这样的:
$parts = array_map(function($num) {
return (int) $num;
},explode(':','03:05:01'));
$timeA = new DateTime('2015-10-09 13:40:14');
$timeB = new DateInterval(sprintf('PT%uH%uM%uS',$parts[0],$parts[1],$parts[2]));
$timeA->add($timeB);
echo $timeA->format('Y-m-d H:i:s');