我有一个日期返回作为MySQL查询的一部分在形式2010-09-17。
我想设置变量$Date2到$Date5,如下所示:
$Date = $Date + 1
$Date = $Date + 2
从而返回2010-09-18,2010-09-19,等等。
我试过了
date('Y-m-d', strtotime($Date. ' + 1 day'))
但是这给了我$ date之前的日期。
以“Y-m-d”格式获取日期的正确方法是什么,以便它们可以在另一个查询中使用?
我有一个日期返回作为MySQL查询的一部分在形式2010-09-17。
我想设置变量$Date2到$Date5,如下所示:
$Date = $Date + 1
$Date = $Date + 2
从而返回2010-09-18,2010-09-19,等等。
我试过了
date('Y-m-d', strtotime($Date. ' + 1 day'))
但是这给了我$ date之前的日期。
以“Y-m-d”格式获取日期的正确方法是什么,以便它们可以在另一个查询中使用?
当前回答
您也可以使用以下格式
strtotime("-3 days", time());
strtotime("+1 day", strtotime($date));
你可以这样堆叠更改:
strtotime("+1 day", strtotime("+1 year", strtotime($date)));
注意这种方法与其他答案之间的区别:您可以将时间戳作为strtotime的第二个参数传入,而不是将值+1 day和<timestamp>连接起来。
其他回答
这个作品。您可以使用它的天,月,秒,并重新格式化日期根据您的要求
public function reformatDate($date, $difference_str, $return_format)
{
return date($return_format, strtotime($date. ' ' . $difference_str));
}
例子
echo $this->reformatDate('2021-10-8', '+ 15 minutes', 'Y-m-d H:i:s');
echo $this->reformatDate('2021-10-8', '+ 1 hour', 'Y-m-d H:i:s');
echo $this->reformatDate('2021-10-8', '+ 1 day', 'Y-m-d H:i:s');
使用变量表示天数
$myDate = "2014-01-16";
$nDays = 16;
$newDate = strtotime($myDate . '+ '.$nDays.' days');
echo new Date('d/m/Y', $newDate); //format new date
另一种选择是将日期字符串转换为时间戳,然后添加适当的秒数。
$datetime_string = '2022-05-12 12:56:45';
$days_to_add = 1;
$new_timestamp = strtotime($datetime_string) + ($days_to_add * 60 * 60 * 24);
在此之后,您可以使用PHP的各种日期函数之一将时间戳转换为日期对象或将其格式化为人类可读的字符串。
$new_datetime_string = date('Y-m-d H:i:s', $new_timestamp);
如果你使用的是PHP 5.3,你可以使用DateTime对象和它的add方法:
$Date1 = '2010-09-17';
$date = new DateTime($Date1);
$date->add(new DateInterval('P1D')); // P1D means a period of 1 day
$Date2 = $date->format('Y-m-d');
查看DateInterval构造函数手册页,了解如何构造其他时间段来添加到日期中(2天将是'P2D', 3天将是'P3D',等等)。
如果没有PHP 5.3,你应该能够像你那样使用strtotime(我已经测试过了,它在5.1.6和5.2.10中都有效):
$Date1 = '2010-09-17';
$Date2 = date('Y-m-d', strtotime($Date1 . " + 1 day"));
// var_dump($Date2) returns "2010-09-18"
你所要做的就是像这样用days代替day:
<?php
$Date = "2010-09-17";
echo date('Y-m-d', strtotime($Date. ' + 1 days'));
echo date('Y-m-d', strtotime($Date. ' + 2 days'));
?>
并且输出正确:
2010-09-18
2010-09-19