我有一个日期返回作为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>连接起来。

其他回答

这里有一个简单的解决方法。

<?php
   $date = "2015-11-17";
   echo date('Y-m-d', strtotime($date. ' + 5 days'));
?>

输出将是:

2015-11-22

解决方案已经从这里找到-如何在PHP中添加日期

您也可以使用以下格式

strtotime("-3 days", time());
strtotime("+1 day", strtotime($date));

你可以这样堆叠更改:

strtotime("+1 day", strtotime("+1 year", strtotime($date)));

注意这种方法与其他答案之间的区别:您可以将时间戳作为strtotime的第二个参数传入,而不是将值+1 day和<timestamp>连接起来。

从PHP 5.2开始,你可以对DateTime对象使用modify:

http://php.net/manual/en/datetime.modify.php

$Date1 = '2010-09-17';
$date = new DateTime($Date1);
$date->modify('+1 day');
$Date2 = $date->format('Y-m-d');

在加上月份时要小心……(在较小的程度上,几年)

要向某个日期添加特定天数,请使用以下函数。

function add_days_to_date($date1,$number_of_days){
    /*
    //$date1 is a string representing a date such as '2021-04-17 14:34:05'
    //$date1 =date('Y-m-d H:i:s'); 
    // function date without a secrod argument returns the current datetime as a string in the specified format
    */
    $str =' + '. $number_of_days. ' days';
    $date2= date('Y-m-d H:i:s', strtotime($date1. $str));
    return $date2; //$date2 is a string
}//[end function]

都必须使用以下代码:

$nday = time() + ( 24 * 60 * 60);    
echo 'Now:       '. date('Y-m-d') ."\n";    
echo 'Next Day: '. date('Y-m-d', $nday) ."\n";