douji9184 2016-10-18 10:49
浏览 98
已采纳

MySQL没有时区表 - 需要将欧洲/伦敦与UTC进行比较

I am working with a table that has a DATETIME type field which gets updated after the PHP datetime default timezone is set:

date_default_timezone_set("Europe/London");
$date=date("Y-m-d H:i:s");

mysql_query("UPDATE mytable SET status='$status', statusupdated='$date' WHERE id='$id'");

I need to create a query that gets all the results after a certain ($landing) time (UTC):

mysql_query("SELECT * FROM mytable WHERE CONVERT_TZ(`statusupdated`, 'GMT', 'UTC') > $landingtime");

However the database doesn't have any timezone tables so the above doesn't work.

How can I standardise the query so I can compare statusupdated against UTC?

NOTES:

I am unable to edit the database data types as this is an external database. Thanks

To simplify the question I have simplified the code (I know about SQL injection etc) and I know about the deprecated functions. Thanks.

  • 写回答

1条回答 默认 最新

  • dousui4577 2016-10-18 11:40
    关注

    Worked out how to do this.

    I can convert @@session.time_zone to '+00.00'. Lovely!

    mysql_query("SELECT * FROM mytable WHERE CONVERT_TZ(`date`, @@session.time_zone, '+00:00') > $landingtime");
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 angular开发过程中,想要读取模型文件,即图1的335行,会报404错误(如图2)。但我的springboot里配置了静态资源文件,如图3。且在该地址下我有模型文件如图4,请问该问题该如何解决呢?
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 vite打包后,页面出现h.createElement is not a function,但本地运行正常
  • ¥15 Java,消息推送配置