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)
| 归档时间: |
|
| 查看次数: |
6714 次 |
| 最近记录: |