热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

如何将java.util.Date存储到UTCGMT时区的My

简短的答案是:


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

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

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

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


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



长答案是这样的:

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


  1. ,而不是使用服务器的本地时区(当然,除非是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点)!



    • 在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();

希望这可以帮助!:-)





推荐阅读
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
author-avatar
Yy石小雪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有