我有一个表(比方说)存储命中:
id | datetime | ...
-----------------------------------
1 | 2014-05-30 15:19:00 | ...
2 | 2014-06-01 12:14:00 | ...
3 | 2014-06-04 13:06:00 | ...
4 | 2014-06-04 17:26:00 | ...
5 | ... | ...
用户可以生成他们可以选择日期范围的报告。但是我想让用户能够使用他们自己的时区首选项。
目前我使用这样的查询来选择今天的列:
... WHERE datetime >= CURDATE()
我该怎么做?将日期存储为 unixtime 更好吗? 我已经阅读了 Google 上的所有结果,但我很困惑。
这个查询会被多次调用,所以性能非常重要
最佳答案
您可以从用户那里获取时区首选项作为国家名称,并使用它来相应地设置时区:
SET time_zone = 'Europe/Helsinki';
要为日期范围创建过滤器,您可以使用像这样的普通 where 条件:
select * from table where hit_date>=startdate and hit_date<enddate
性能:
您可以使用日期时间列创建索引,这将大大提高性能。需要记住的一点是,使用经常更新的内容作为索引通常不是一个好主意。
注意:
假设您将页面点击日期时间存储在您自己的时区中,例如亚洲/北京,并且用户将其更改为“欧洲/赫尔辛基”,在这种情况下,您应该在执行查询之前相应地转换时区使用
检索正确的结果SELECT CONVERT_TZ('2004-01-01 12:00:00','Asia/Beijing','Europe/Helsinki');
通俗地说,您应该在执行用户查询之前找到您所在时区的时间,因为数据库是根据您所在的时区填充的。
用户时区------------>你的时区-------------->查询
关于PHP、MySQL : SELECT by individual timezone preferences,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24114511/