- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我面临时区问题。让我尝试描述一下:
我的Web应用程序和数据库运行在时区(欧洲/马德里,即UTC + 1)与本地时区(印度/加尔各答,即UTC + 5:30)不同的服务器上。
可以说我的当地当前时间是:IST 2014年1月15日星期三14:35:00和
该服务器当前时间为:2014年1月15日星期三CET 2014年,即滞后4:30小时。
现在,当我尝试使用网页(GUI)中的日历选择将日期时间保存在数据库上时,可以说,我选择的日期时间是:Wed Jan 15 18:30:00,要保存的最终日期在DB中成为1月15日星期三14:00:00(请参见滞后时间4:30)。
让我告诉您上述流程的编码部分。
从我的网页日历中选择->将所选日期时间的时间戳(长)传递给我的服务器端控制器->在服务器端后,我正在构造java.util.Date对象并保存到DB,如下所示:
java.util.Date newDt = new java.util.Date(timeStampInMillis);
最佳答案
不清楚的问题
您的问题可能会写得更好。您应该尝试将其缩小为非常具体的示例。您甚至都没有指定讨论中的毫秒值。
服务器时间
几乎应始终将服务器设置为没有夏令时的UTC / GMT时区。在某些系统(例如Mac OS X)上,这很困难。在这种情况下,将机器的时区设置为“ Atlantic / Reykjavik”,因为冰岛全年都处于UTC / GMT时间,而没有任何夏令时的废话。
避免使用java.util.Date
众所周知,与Java捆绑在一起的java.util.Date和.Calendar类很麻烦。
难点之一是,当Date没有分配时区时,其toString
方法在呈现字符串时使用默认时区。因此,对于天真的程序员来说,日期似乎有一个时区,而没有。
使用Java 8捆绑的Joda-Time库或新的java.time。*类。在StackOverflow上搜索两者的许多示例。
全球化思考,本地化呈现
您的大多数业务逻辑和数据库存储都应在UTC / GMT中完成(无时区偏移)。诸如Postgres之类的称职数据库默认情况下会这样做。
通常,仅切换到时区以呈现给用户。
时区
始终指定一个时区。不要依赖默认时区,因为这会导致生产意外或任何机器更改其时区的时间。
避免使用三个字母代码,因为它们既不是标准化的也不是唯一的。使用正确的时区名称。
在this one之类的列表中查找您的时区名称(略过时,请阅读详细信息)。我认为您在问题中提到“印度/加尔各答”是不正确的。应该是“亚洲/加尔各答”。
ISO 8601
如果必须serialize,请仅使用ISO 8601格式。这种格式是人类可读,明确且明确定义的。
印度时区示例:2014-01-19T12:38:31 + 05:30
UTC / GMT“ Zulu”的示例:2013-11-22T18:28.023Z
java.sql。*类
使用java.sql。*类通过JDBC与数据库进行通信。
您可以通过传递自1970年开始的毫秒数来构造java.sql.Timestamp对象。在Joda-Time中,调用getMillis
获取要传递的值。
避免毫秒
通常,我宁愿避免以毫秒为单位跟踪时间。人们容易陷入麻烦,因为某些系统以秒,毫秒或纳秒为单位来跟踪时间。此外,有许多时代在使用,而不总是1970年第一天的Unix风格。
我尝试通过以下任一方法:
日期时间对象,例如Joda-Time DateTime实例
ISO 8601字符串。
范例程式码
但是,如果您确定毫秒值代表了UTC / GMT自1970年第一天以来的真实毫秒数,请在Joda-Time中使用这种代码。请注意,“ L”将数字标记为长整数。
DateTime dateTime = new DateTime( 1390276603054L );
DateTime dateTimeSpain = dateTime.toDateTime( DateTimeZone.forID( "Europe/Madrid" ) );
DateTime dateTimeIndia = dateTime.toDateTime( DateTimeZone.forID( "Asia/Kolkata" ) );
DateTime dateTimeUtcGmt = dateTime.toDateTime( DateTimeZone.UTC );
// For database.
java.sql.Timestamp timestamp = new java.sql.Timestamp( dateTimeSpain.getMillis() );
System.out.println( "dateTime (default time zone): " + dateTime );
System.out.println( "dateTimeSpain: " + dateTimeSpain );
System.out.println( "dateTimeIndia: " + dateTimeIndia );
System.out.println( "dateTimeUtcGmt: " + dateTimeUtcGmt );
System.out.println( "timestamp: " + timestamp ); // "toString" uses default time zone.
dateTime (default time zone): 2014-01-20T19:56:43.054-08:00
dateTimeSpain: 2014-01-21T04:56:43.054+01:00
dateTimeIndia: 2014-01-21T09:26:43.054+05:30
dateTimeUtcGmt: 2014-01-21T03:56:43.054Z
timestamp: 2014-01-20 19:56:43.054
java.util.Date
,
Calendar
和
SimpleDateFormat
。
java.sql.*
类。
Interval
,
YearWeek
,
YearQuarter
和
more。
关于java - 从时间戳构造java.util.Date对象时发生时区问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21228755/
数据框有一个字符串类型的日期列 '2017-01-01' 它被转换为 DateType() df = df.withColumn('date', col('date_string').cast(Dat
这个问题在这里已经有了答案: What is "x && foo()"? (5 个答案) 关闭 8 年前。 我在 bootstrap-datepicker.js 文件中遇到过这个。 作者在_setD
我有一个数据库 utc 字符串,我正在传递到 Date(attrs.endDate),然后通过 new Date() 减去当前的 utc 日期,但我无法得到它来为我提供 2 个 utc 日期的正确差异
这个问题在这里已经有了答案: how to determine if 2 dates object equals each other? [duplicate] (3 个答案) 关闭 6 年前。 我
这个问题已经有答案了: How can I convert "/Date(1399739515000)/" into date format in JavaScript? (3 个回答) 已关闭 8
根据MDN ,我们只能将以下类型的参数传递给 Date 构造函数: new Date(); new Date(value); // Unix timestamp new Date(dateString
我从表中获取所有项目: endDate >= 现在 endDate 为 NULL published 等于 1。 这是我所拥有的,但它给了我 0 个项目: $items = Items::orderB
此查询需要很长时间才能完成。当我将 WHERE 子句设置为 new_dl >= '2014-01-01' 时,查询大约需要 6 分钟才能浏览大约 3 个月的数据。现在不知道为什么这个应该从 12 个月
我有一个正在为项目开发的小型 Java 程序,它使用 JavaMail 从指定的 URI 中提取用户的收件箱,然后开始处理消息。 在 Outlook 中,属性菜单中有一个功能可以设置邮件的到期日期,它
我想在获取 Date.getHours()、Date.getMinutes() 和 Date.getSeconds() 的值后格式化输出>. 这是一条漫长的路: var dt = new Date()
我发现java.text.DateFormat有两种格式化日期的方法。一种是采用 Date 参数,另一种是采用 Object 参数。我检查了DateFormat源代码,似乎他们调用了不同的内部方法。
我有两个对象,p4 和 p5,它们都具有 Date 属性。在某些时候,构造函数工作正常: p4.setClickDate(new Date(System.currentTimeMillis() - 8
我是使用 Sequelize 和 Node.js 的新手,但我的代码中存在日期比较问题。 User.findOne({ where: { resetToken: passwordToken,
我正在使用一个名为 fullcalendar 的 jquery 日历。当用户单击某一天时,他们将被发送到另一个页面以创建该天的事件。单击的日期作为 date 提供。然后通过下面的函数运行将其转换为 U
我有一个列表列表,每个列表中都有整数值,代表 8 年期间的日期。 dates = [[2014, 11, 14], [2014, 11, 13], ....., [2013, 12, 01]
我有两个表: 首先是TimeValues(示例) time | value 12/28/18 | 5.6 01/03/19 | 5.6 01/04/19 | 5.6 01/09/19 | 5.
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
像这样实例化的日期对象: new Date("2011-12-13") 返回一个认为自己是星期一的日期对象: Date {Mon Dec 12 2011 16:00:00 GMT-0800 (PST)
我需要选择入住日期和退房日期在指定日期范围之间的房价。这些费率根据其条件单独命名。房费取决于所选日期。这是我的代码: rate_eb rate_name rate_starts rat
我有 [Int64:[String:String]] 其中 Int64 是时间戳。如何检测和删除 [String:String] 中的参数之一是 ["name"] = "test" 并重复多次的同一天
我是一名优秀的程序员,十分优秀!