When using PHP's DateTime to convert a stored date to a different timezone later, do you need to store the time information (e.g., 2012-12-31 00:00:00 instead of just 2012-12-31)? It appears that if I just store the date, the timezone conversion is inaccurate so I'm not sure if time information is really needed or I'm just missing something?
2条回答 默认 最新
- dongshun5963 2012-11-21 19:24关注
Timezone conversions work by hour offsets - with out the time stored (atleast hours), you can't accurately calculate the difference.
An example to consider - say you want to group data by day, the dates are stored in
UTC
but your client is inPST
.A row was created on
2012-12-31 08:00:00
inUTC
, but you stored2012-12-31
.$date = new DateTime('2012-12-31', new DateTimeZone('UTC') ); echo $date->setTimezone( new DateTimeZone('America/Los_Angeles') )->format('Y-m-d'); //2012-12-30 $datetime = new DateTime('2012-12-31 08:00:00', new DateTimeZone('UTC') ); echo $datetime->setTimezone( new DateTimeZone('America/Los_Angeles') )->format('Y-m-d'); //2012-12-31
The date should reflect
2012-12-31
in PST, but with out the hour offset it would be converted incorrectly.Also, as Samuel Cook answered, unless you explicitly store the
datetime
in your database under a single timezone, you should store the timezone as well, so you know what your converting from.本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥60 pb数据库修改或者求完整pb库存系统,需为pb自带数据库
- ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
- ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
- ¥20 神经网络Sequential name=sequential, built=False
- ¥16 Qphython 用xlrd读取excel报错
- ¥15 单片机学习顺序问题!!
- ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
- ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
- ¥15 相敏解调 matlab
- ¥15 求lingo代码和思路