- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我们在数据库中有一个名为 Record 的表,其中有一些记录。它有以下几列
Id(uniqueidentifier)
SubmittedDate(DateTime)
RecordNumber(uniqueidentifier)
下面一行代表一行记录,
Id RecordNumber SubmittedDate
'CD458C6D-9F45-41C1-85D8-E3D8287A82B4', 'EBB5DE3A-4B14-4112-AF51-0F8367FE3383' '2016-11-02 08:27:17.300'
用户可以从任何时区提交记录。作为最佳实践的一部分,我们将 DateTime 保存为 UTC。因此,根据用户时区,我们将日期时间转换为 UTC 并将其保存在表中。
现在,我必须返回结果作为用户按日期提交的记录数。我们必须根据用户时区返回记录。
如果用户在 2016 年 11 月 22 日凌晨 01:00 提交了 10 条记录,并且在 2016 年 11 月 21 日没有提交任何记录并且用户属于 IST 时区。在服务器端,我们将 22Nov2016 01:00AM 转换为 IST 并将其存储为 21Nov2016 09:00PM UTC
当同一用户查询获取 11 月 24 日最后 5 天的记录时,我们将当前用户时区的偏移量即 (+5:30) 添加到 SubmittedDate 列并相应地获取记录。因此,我们应该根据用户时区获得用户提交的正确记录数。在将 UTC 偏移量添加到 SubmittedDate 日期后,我将获得正确数量的记录,即 2016 年 11 月 22 日的日期为 10。
当我们在夏令时期间更改 UTC 偏移时,即当时区从 PST 转换为 PDT 时,反之亦然时,此解决方案将不起作用。
为了克服这个问题,我们在用户提交记录时在用户表中添加了时区列
Id(唯一标识符)提交日期(日期时间)记录号(唯一标识符)提交的时区(varchar)
因此,a) 当用户从启用夏令时的时区查询记录并且提交的记录也在启用夏令时时提交,我们不会做任何抵消。
b) 当用户从启用夏令时的时区查询记录,并在夏令时关闭时提交记录,在这种情况下,我们将增加 1 小时的偏移量。
c) 当用户从夏令时关闭的时区查询记录并在夏令时开启时提交记录时,在这种情况下,我们将添加 -1 小时以进行偏移。
d) 当用户从夏令时关闭的时区查询记录并且提交的记录也在夏令时关闭时提交,我们不会做任何抵消。
这是处理不同时区的时区/夏令时的正确方法吗?
注意:我们正在确定已提交的记录在夏令时打开时也已提交,列 SubmittedTimeZone 值的最后两个词为“DAYLIGHT TIME”像“阿拉斯加夏令时”、“东部夏令时”
这里有可能夏令时在一个时区开启,而在另一个时区关闭。可能我们必须根据提交的日期和提交的时区列计算请求用户时区的偏移量。
最佳答案
在这种情况下,我们不能将偏移量添加到提交的日期时间,因为偏移量会随着夏令时的影响而改变。
因此,用户提交记录时的偏移量和查询提交的记录数时的偏移量可以不同。这将导致不正确的记录数。
解决这个问题的方法是获取请求用户的时区,并将每条记录的 submittedDatetime 值转换为请求用户的时区,然后根据日期计算提交的记录数。
关于c# - 根据用户时区的 UTC 时区更改计算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40745067/
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 3 年前。 Improve th
当我使用 UTC() 函数获取纪元时间(1970 年 1 月 1 日)的总秒数时。但再次使用“new Date(milliseconds)”构造函数将相同的秒数转换为 Date 并没有给出 UTC d
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我有一个关于 Swift 类型 TimeZone 的问题。我需要一个 UTC0 时区来格式化我的 Date 对象。我正在像这样创建 TimeZone 对象。 let utcTimeZone = Tim
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 5 年前。 Improve t
我遇到了以下代码: datetime.datetime.utcnow().replace(tzinfo=tzutc()) 我看不到 Replace() 调用正在做什么,从阅读文档来看,它似乎将其转换为
我在应用程序中将时区设置为 UTC,如下所示: // set default time zone to UTC TimeZone.setDefault(TimeZone.getTimeZone(Zon
我需要两件事: 将当前时间转换为 UTC(这样我就可以以 UTC 格式存储日期)--> result = java.util.Date. 将加载日期(UTC 格式)转换为任何时区 --> result
我想将日期从本地转换为 UTC,再将 UTC 转换为本地。 例如。 2015 年 4 月 1 日,12:00 PM 然后是 UTC 2015 年 4 月 1 日下午 5:30 对我来说是本地时间,但我
嗨,我有一个长度为几百万的字符向量( rr ),它以 %Y-%m-%d %H:%M:%S 格式表示时间和日期戳。记录在澳大利亚/悉尼。 如何获得代表这一点的 POSIXct 对象(快速)。 我找到了
static String createUTCTime() { Calendar cal = new GregorianCalendar(TimeZone.getTimeZone("UTC")
我正在尝试将语言环境时间转换为 UTC,然后将 UTC 转换为语言环境时间。但我没有得到结果。 public class DateDemo { public static void main(Stri
我正在寻找用纯 Javascript 替换 moment js 功能 - 我需要重新工作的项目将来不会有 moment.js 可用。我已经有一段时间没有使用 javascript Date 了,所以需
我想获取与 UTC 相关的用户时区,然后将其显示为 UTC +/- 。例如,加利福尼亚用户应显示 UTC -8(或 -7,视情况而定),而巴林用户应显示 UTC +3,等等。 下面的代码并没有告诉我它
我正在尝试将毫秒转换为 UTC 日期对象,如下所示 - var tempDate = new Date(1465171200000); // --> tempDate = Mon Jun 06 201
我一直很困惑为什么下面的代码会导致我的日期从 25 日更改为 24 日 SimpleDateFormat sd = new SimpleDateFormat("dd/MM/yyyy"); DateTi
我需要将字符串转换为 UTC 日期,然后将 UTC 日期转换为本地日期。 这是我的代码: var dateStr = "9/8/2015 12:44:00 PM"; console.log(strto
我正在用 PHP 编写一个 Twitter 网络服务。当用户登录时,我收到此节点: -18000 我必须更改脚本的时区,以便它适应用户的实际时区。我为此找到的唯一 php 函数是: date_defa
在 PHP 文档中,list of supported time zones , UTC 被列出两次: UTC 等/UTC 这两者之间有什么概念上的区别,还是它们只是同义词? 最佳答案 首先回答问题:
在 PHP 文档中,list of supported time zones , UTC 被列出两次: UTC 等/UTC 这两者之间有什么概念上的区别,还是它们只是同义词? 最佳答案 首先回答问题:
我是一名优秀的程序员,十分优秀!