仅以UTC格式存储Doctrine2 DateTime

Mat*_*att 11 timezone datetime doctrine-orm

有类似的问题,但我找不到任何与Doctrine2配置有关的问题,所以这里有......

我已经读过这个描述Doctrine2时区的页面,我只是想澄清一下,因为目前还不清楚如何实际使用它:http://doctrine-orm.readthedocs.org/en/latest/cookbook/working-与-datetime.html

我希望以UTC格式存储日期时间,以便每个用户可以根据其位置拥有关联的时区,但数据通常存储.

基本上,数据是商店的营业时间(例如,上午9点开放,下午6点关闭).商店将跟踪其时区,因此当商店中的人设置"开放"时间时,他们正在处理商店的时区,时间转换为UTC并存储在数据库中.接下来,当其他用户查看商店营业时间时,他们将在自己的时区或商店时区中看到营业时间.这应该没关系,因为我有UTC时间,所以我可以将它们转换为任何时区.

所以Doctrine文档显示了这个例子:

class UTCDateTimeType extends DateTimeType
{
// ...
}
Run Code Online (Sandbox Code Playgroud)

但它没有说明如何使用它.我是否必须将列声明为"UTCDateTime"而不是"DateTime"?这个类需要在哪里生活,以便Doctrine知道该类型存在?

Mat*_*att 18

我刚刚发现这篇关于Timestampable行为的帖子的一部分,这似乎是一个更简单的解决方案:

config.yml

doctrine:
    dbal:
        types: 
            datetime: Acme\DoctrineExtensions\DBAL\Types\UTCDateTimeType
Run Code Online (Sandbox Code Playgroud)