mysql时区时间戳_如何将java.util.Date存储到UTC / GMT时区的MySQL时间戳字段中?

小编典典

简短的答案是:

在my.cnf中添加“ default-time-zone = utc”

在您的代码中,请始终在UTC中“思考”,除非为用户显示日期

使用JDBC获取/设置日期或时间戳时,请始终使用Calendar参数,并将其设置为UTC:

resultset.getTimestamp(“ my_date”,Calendar.getInstance(TimeZone.getTimeZone(“

UTC”)));;

将服务器与NTP同步,或仅依靠数据库服务器告诉您现在几点。

长答案是这样的:

在处理任何数据库中的日期和时区以及任何客户端代码时,我通常建议以下策略:

将数据库配置为使用UTC时区 ,而不是使用服务器的本地时区(当然,除非是UTC)。

如何执行此操作取决于您的数据库服务器。有关MySQL的说明,请参见:http : //dev.mysql.com/doc/refman/5.0/en/time-zone-support.html。基本上,您需要在my.cnf中编写以下代码:default-time-zone = utc

这样,您可以在任何地方托管数据库服务器,轻松更改托管位置,并且更一般地在服务器上操作日期而不会产生任何歧义。

如果您确实更喜欢使用本地时区,则建议至少关闭“夏令时”,因为数据库中的日期含糊不清可能是一场噩梦。

例如,如果您正在构建电话服务,并且正在数据库服务器上使用“夏令时”,那么您就会遇到麻烦:将无法判断是否从“ 2008-10-26 02:30”致电的客户“ 00:00”到“ 2008-10-26 02:35:00”实际上调用了5分钟或1小时5分钟(假设夏令时发生在10月26日凌晨3点)!

在您的应用程序代码中,除向用户显示日期外,始终使用UTC日期。

在Java中,从数据库读取时,请始终使用:

时间戳myDate = resultSet.getTimestamp(“

my_date”,Calendar.getInstance(TimeZone.getTimeZone(“ UTC”)));

* 如果您不这样做,则将假定时间戳位于您的本地TimeZone中,而不是UTC。

同步服务器或仅依赖数据库服务器的时间

如果您的Web服务器位于一台(或多台)服务器上,而数据库服务器位于另一台服务器上,则强烈建议您将其时钟与NTP同步。

或者,仅依靠一台服务器告诉您现在几点了。通常,数据库服务器是要求时间的最佳服务器。换句话说,避免这样的代码:

prepareStatement = connection.prepareStatement(“ UPDATE my_table SET my_time

=?WHERE […]”);

现在的java.util.Date =新的java.util.Date(); // 当地时间!:-(

prepareStatement.setTimestamp(1,new Timestamp(now.getTime()));

int结果= prepareStatement.execute ();

* 而是依靠数据库服务器的时间:

prepareStatement = connection.prepareStatement(“ UPDATE my_table SET my_time =

NOW()WHERE […]”);

int结果= prepareStatement.execute();

希望这可以帮助!:-)

2020-11-13

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值