升级到 PHP 5.3 后,我的应用程序返回时间戳类型为“2010-12-15-10.23.22.716000”的 DB2 列。这导致 PHP DateTime 函数出现问题,因为它失败了
$time = new DateTime("2010-12-15-10.23.22.716000");
无法在位置 25 (0) 解析时间字符串 (2010-12-15-10.23.22.716000):意外字符
DB2 时间戳的准确性似乎太高了。我可以以某种方式强制连接更改时间戳格式,并将数据提取到其中吗?
我正在使用 db2_connect 函数连接到数据库,如下所示:
$this->connection = db2_connect ( $config ['dsn'], $config ['username'], $config ['password'] );
编辑: 我想使用下面提到的解决方案,但它对我不起作用,并且在我的系统(AS400)上运行很奇怪。我有: $timeRec = DateTime::createFromFormat('Ymdh.isu',$value);
$value = $timeRec->format('Y-m-d H:i:s');
$value = new DibiDateTime($value);
如果我在 ->format 之后执行 var_dump($value),则返回正确的字符串,但如果我尝试将此字符串提供给 DibiDateTime,则具有:
public function __construct($time = 'now', DateTimeZone $timezone = NULL)
{
if ($timezone === NULL) {
parent::__construct($time);
}
}
然后它失败了:
非对象上的函数 format()
即使我之前检查过 var_dump($timeRec) 是正确的 DateTime 对象。