$combinedDT = date('Y-m-d H:i:s', strtotime('$date $time'));
日期格式 2013-10-14
时间格式 23:40:19
当我尝试存储到日期时间数据类型时,出现了零值。
你目前正在使用strtotime('$date $time')
。被单引号包裹的变量不会被解析。如果你使用单引号,PHP会将其视为字面字符串,strototime()
会尝试将字符串$date $time
转换为时间戳。
这样做会失败,这就解释了为什么你得到了错误的结果。
你需要使用双引号:
$combinedDT = date('Y-m-d H:i:s', strtotime("$date $time"));
^ ^
对于那些使用 DateTime 对象的人:
$date = new DateTime('2017-03-14');
$time = new DateTime('13:37:42');
// Solution 1, merge objects to new object:
$merge = new DateTime($date->format('Y-m-d') .' ' .$time->format('H:i:s'));
echo $merge->format('Y-m-d H:i:s'); // Outputs '2017-03-14 13:37:42'
// Solution 2, update date object with time object:
$date->setTime($time->format('H'), $time->format('i'), $time->format('s'));
echo $date->format('Y-m-d H:i:s'); // Outputs '2017-03-14 13:37:42'