我想将从PHP中生成的当前日期存储到MongoDB集合中,作为一个formate格式。
ISODate("2012-11-02T08:40:12.569Z")
但是,我无法在php中生成这样的日期,它将以ISODate格式存储在MongoDB中。
这就是我所做的。
$d = new MongoDate(time());
echo $d;
它正在输出类似的东西,
0.00000000 1353305590
这不是我需要的格式。怎么做?
发布于 2012-11-19 06:24:16
可以运行__toString
函数,也可以使用sec
字段
__toString
将在usecs中返回一个时间戳,在将秒与毫秒分开后,可以将时间戳传递给date()
-在这里读取:http://us1.php.net/manual/en/mongodate.tostring.php
或者,我个人更喜欢让mongodb只返回几秒钟,这可以直接插入到date()
-阅读这里:http://php.net/manual/en/class.mongodate.php。
另外,如果您正在为当前生成一个MongoDate(),则不需要指定time();
为了返回一个In日期,您需要这样做:
echo date(DATE_ISO8601, (new MongoDate())->sec);
..。
$exampleDate = new MongoDate();
echo date(DATE_ISO8601, $exampleDate->sec);
编辑:要保存ISO日期,您需要执行以下操作:
$mongoDateObject = new MongoDate(strtotime("2012-11-02T08:40:12.569Z"));
发布于 2015-10-07 17:32:44
为了清晰起见,让我们考虑以下用例:
您需要将简化的扩展ISO 8601格式的字符串(例如由Javascript的Date.prototype.toISOString()
返回)转换到和从MongoDate
对象中转换,同时在转换过程中保持最大的精度。
在这种格式中,字符串总是有24个字符长:YYYY-MM-DDTHH:mm:ss.sssZ
。时区总是零UTC偏移量,用后缀Z
表示。
为了保持毫秒,我们必须利用PHP的DateTime
对象。
从字符串到MongoDate
的
$stringDt = "2015-10-07T14:28:41.545Z";
方法1(使用date_create_from_format
):
$phpDt = date_create_from_format('Y-m-d\TH:i:s.uP', $stringDt);
$MongoDt = new \MongoDate($phpDt->getTimestamp(), $phpDt->format('u'));
方法2(使用strtotime
):
$MongoDt= new \MongoDate(strtotime ($stringDt),
1000*intval(substr($stringDt, -4, 3)) // cut msec portion, convert msec to usec
);
从MongoDate
到string的
$MongoDt = new \MongoDate(); // let's take now for example
$stringDt =
substr(
(new \DateTime())
->setTimestamp($MongoDt->sec)
->setTimeZone(new \DateTimeZone('UTC'))
->format(\DateTime::ISO8601),
0, -5) // taking the beginning of DateTime::ISO8601-formatted string
.sprintf('.%03dZ', $MongoDt->usec / 1000); // adding msec portion, converting usec to msec
希望这能有所帮助。
发布于 2019-05-28 11:25:00
convert ISO date time in UTC date time here :
$timestamp = $quicky_created_date->__toString(); //ISO DATE Return form mongo database
$utcdatetime = new MongoDB\BSON\UTCDateTime($timestamp);
$datetime = $utcdatetime->toDateTime();
$time=$datetime->format(DATE_RSS);
$dateInUTC=$time;
$time = strtotime($dateInUTC.' UTC');
$dateInLocal = date("d M Y", $time);
echo $dateInLocal; die;
https://stackoverflow.com/questions/13448614
复制相似问题