gpt4 book ai didi

PHP、MySQL : SELECT by individual timezone preferences

转载 作者:行者123 更新时间:2023-11-29 00:13:00 25 4
gpt4 key购买 nike

我有一个表(比方说)存储命中:

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com