我使用了一个新的Date()对象来填充MySQL DB中的一个字段,但是存储在该字段中的实际值在我的本地时区中。
如何配置MySQL以将其存储在UTC / GMT时区?
我认为,配置连接字符串会有所帮助,但我不知道如何。连接字符串中有许多属性,例如useTimezone,serverTimzone,useGmtMillisForDatetimes,useLegacyDatetimeCode,…
简短的答案是:
resultset.getTimestamp(“ my_date”,Calendar.getInstance(TimeZone.getTimeZone(“
UTC”)));;
长答案是这样的:
在处理任何数据库中的日期和时区以及任何客户端代码时,我通常建议以下策略:
将数据库配置为使用UTC时区 ,而不是使用服务器的本地时区(当然,除非是UTC)。
如何执行此操作取决于您的数据库服务器。有关MySQL的说明,请参见:http : //dev.mysql.com/doc/refman/5.0/en/time-zone-support.html。基本上,您需要在my.cnf中编写以下代码:default-time-zone = utc
这样,您可以在任何地方托管数据库服务器,轻松更改托管位置,并且更一般地在服务器上操作日期而不会产生任何歧义。
如果您确实更喜欢使用本地时区,则建议至少关闭“夏令时”,因为数据库中的日期含糊不清可能是一场噩梦。
在您的应用程序代码中,除向用户显示日期外,始终使用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();
希望这可以帮助!:-)
问题内容: 我想转换为,但是我也想要小时,分钟和秒,但是java.sql.Date只能用于存储date(没有时间)。我尝试了下面的代码,但它只给出对象的年,月和日。 电流输出: 所需的输出: 问题答案: 该类型仅用于存储日期(无时间)信息,因为它映射到不存储时间的SQL 类型。其方法的作用是: 以日期转义格式yyyy-mm-dd格式化日期。 要获得所需的输出,可以使用,它存储日期 和 时间信息,并
我有一个Java客户机,它正在以UTC格式在MySQL DB中插入(通过CSV和'Load DATA Infile')时间戳(type TIMESTAMP)。我的服务器的时区是“America/New_York”,我需要保留夏令时信息。11月5日凌晨2点是美国东部时间转换到东部时间的时候,时钟拨回一个小时到凌晨1点。例如,11月5日凌晨1:30,发生两次;EDT和EST各一次。 我该如何让服务器区
问题内容: 如何配置JPA /hibernate模式以UTC(GMT)时区在数据库中存储日期/时间?考虑以下带注释的JPA实体: 如果日期为太平洋标准时间(PST)2008-Feb-03 9:30 am,那么我希望数据库中存储2008-Feb-03 5:30 pm的UTC时间。同样,从数据库中检索日期时,我希望将其解释为UTC。因此,在这种情况下530pm是UTC 530pm。显示时,它将被格式化
问题内容: 如何配置JPA /hibernate模式以UTC(GMT)时区在数据库中存储日期/时间?考虑以下带注释的JPA实体: 如果日期是太平洋标准时间(PST)2018-Feb-03 9:30 am,那么我希望数据库中存储2008-Feb-03 5:30 pm的UTC时间。同样,从数据库中检索日期时,我希望将其解释为UTC。因此,在这种情况下,530pm是UTC 530pm。显示时,它将被格式
互联网上有很多关于转换MySQL时间戳的东西,它是如何工作的等等。但我需要的是相反的:知道MySQL在时间戳字段中将每个日期时间数据存储为UTC,我只想直接检索存储的UTC值,而不让MySQL在日期时间与系统/服务器/连接时区之间混淆。 你看,我们已经建立了一个简单的节点。js feeder从几个第三方MySQL数据库读取数据(因此我无法更改它们的时区设置),并将收集的数据保存到Elasticse
问题内容: 我正在使用MongoDB来存储我的数据。Mongo默认将时间戳存储在UTC中。我们在不同时区处理数据。我正在努力将UTC时间戳转换为PDT或IST时间戳。 试图构造一种方法来传递时区(将我的时间戳转换为时区)和timestamp(UTC)。返回指定时区的时间戳的方法。 问题答案: 您可以使用带有所需时区的dateformat并将其应用于日期