0

在我的 postgresql 中,我有一个名为“created”的以下列,其类型为带时区的时间戳

所以我根据我认为是UTC的格式插入了记录。

2015-10-02 09:09:35+08

我正在使用 php Carbon 库,所以我执行了以下操作:

$date = Carbon\Carbon::parse('2015-10-02 09:09:35+08');
echo  $date->->toDatetimeString(); 
//gives result as 2015-10-02 09:09:35

如何使用该库来回显正确的时区,其中包括以上述日期时间格式添加 +8?我使用的 timzezone 是"Asia/Singapore"

时间应打印为本地时间,即 2015-10-02: 17:09:35:

4

3 回答 3

1

使用标准 PHP 试试这个:

$raw = '2015-10-02 09:09:35+08';
$date = substr($raw,0,19);
$tzOffset = (strlen($raw) > 19) ? substr($raw,-3) : 0;
$timestamp = strtotime($date) + (60 * 60 * $tzOffset);
$localTime = date('Y-m-d H:i:s',$timestamp);
echo 'local time:['.$localTime.']';

结果是:

local time:[2015-10-02 17:09:35]

这也可以在没有时区偏移或负时区偏移的情况下工作。

于 2015-10-02T10:17:14.097 回答
0

试试这个:

$timestamp = '2015-10-02 16:34:00';
$date = Carbon::createFromFormat('Y-m-d H:i:s', $timestamp, 'Asia/Singapore');
于 2015-10-02T09:51:50.560 回答
0

您可以使用本机 php 来执行此操作,而无需使用 Carbon:

$time = '2015-10-02 16:34:00+08';
$date = DateTime::createFromFormat('Y-m-d H:i:s+O', $time);
print $date->format('Y-m-d H:i:s') . PHP_EOL;
$date->setTimeZone(new DateTimeZone('Asia/Singapore'));
print $date->format('Y-m-d H:i:s') . PHP_EOL;
$date->setTimeZone(new DateTimeZone('Etc/UTC'));
print $date->format('Y-m-d H:i:s') . PHP_EOL;
于 2015-10-02T10:23:37.170 回答