- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
此时我正在使用 MySQL 数据库的 Java 应用程序中定义我的数据。我需要的一种数据是日期/时间段。我需要在日期时间存储附加数量。
否则我计划使用 Java LocalDateTime
和 MySQL 的 TIMESTAMP
数据类型来存储日期/时间。我计划使用 Java Timestamp
函数转换 LocalDateTime
。
我可以在 MySQL TIMESTAMP
中存储句点吗?它将如何处理“1 天 3 小时 6 分钟”作为 TIMESTAMP
(不处于纪元)?如果不是,什么适合我正在使用的 Java 方法? TIA。
编辑添加的详细信息:这是供本地使用的,每个发行版在一个时区。 PC 上的 Java 应用程序是通过我的 Java GUI 捕获和查看 LocalDateTime
的地方,所需的粒度不超过分钟。然后,它们作为 TIMESTAMP
存储在数据库中。
周期将存储在数据库中的“类次模板”表中,作为相对于模板零点的开始和结束时间段,对于一个轮类周期中的每个类次。我将通过循环处理这些类次模板记录,计算从给定开始日期时间到提前几个月的所有“类次”记录(在 Java 中)。
使用示例:此示例模板将定义 4 名工作人员 8 天的 12 小时轮类,白天和晚上,每类工作 4 天,然后休息 4 天(此模板表中有 16 条记录)。所有值都是调用者零点的加法。每个预设模板记录包含:
网格模板(记录)
(时间段显示为 DD:hh:mm)
第 01 类:00:00:00 – 00:12:00,船员 A
类次 02:00:12:00 – 01:00:00,机组 B
类次 03:01:00:00 – 01:12:00,船员 A
……
09 类:04:00:00 – 04:12:00,机组 C
第 10 类:04:12:00 – 05:00:00,船员 D
…(到第 16 类)
接下来是我想从上述模板记录集中生成的轮类记录,使用 06/01/2016 06:00 作为开始日期时间(或零点)的示例,其中:
类次(记录)
(日期时间显示为 MM/DD/YYYY hh:mm)
类次 01:06/01/2016 06:00 – 06/01/2016 18:00,船员 A
类次 02:06/01/2016 18:00 – 06/02/2016 06:00,船员 B
类次 03:06/02/2016 06:00 – 06/02/2016 18:00,船员 A
……
类次 09:06/05/2016 06:00 – 06/05/2016 18:00,船员 C
第 10 类:06/05/2016 18:00 – 06/06/2016 06:00,船员 D
……
第 17 类:06/09/2016 06:00 – 06/09/2016 18:00,船员 A
第 18 类:06/09/2016 18:00 – 06/10/2016 06:00,船员 B
……
第 25 类:06/13/2016 06:00 – 06/13/2016 18:00,船员 C
第 26 类:06/13/2016 18:00 – 06/14/2016 06:00,船员 D
……
从“offset”到“period”进行了全面编辑,并做了一些澄清
最佳答案
在日期时间工作中,术语“偏移量”通常指的是与 UTC 的偏移量。偏移量是 UTC 线之前(东)或之后(西)的小时数、分钟数和秒数。时区是一组规则,用于处理偏移量调整以处理夏令时 (DST) 等异常情况。
您需要的术语是“elapsed”,以跟踪某些开始和停止时刻之间发生的时间量。
要跟踪从开始到停止的原始两个时刻,可以 (a) 创建您自己的间隔类来存储一对 Instant
或 ZonedDateTime
对象或 (b ) 使用 Interval
ThreeTen-Extra 中的类扩展 java.time 类的项目(310 是 the JSR defining java.time 的数量)。
要跟踪未附加到时间线的时间跨度,请使用 Duration
类(class)。查看Oracle Tutorial on Period and Duration .持续时间跟踪总秒数加上几分之一秒(以纳秒为单位)。
Instant start = Instant.now();
Thread.sleep( 5000 ); // Milliseconds of sleep.
Instant stop = Instant.now();
Duration duration = Duration.between( start , stop );
java.time 类使用 ISO 8601默认情况下用于解析和生成字符串的标准格式作为其日期时间值的文本表示。对于持续时间,标准使用类似 P1DT3H6M
的格式表示“1 天 3 小时 6 分钟”。 P
标记开始(句点),T
将天与小时-分钟-秒分开。您可以存储这些字符串,因为它们可以很容易地由 java.time 处理。但他们当然不会自然而然地排序。
如果您需要对持续时间的长度进行排序或查询,我建议在数据库中写入一个整数,表示持续时间中的总分钟数(您指定的粒度)。您可以通过调用 Duration::toMinutes()
获得该总数.
由于您关心特定的日期和特定的时间跨度,因此您应该不使用Local...
类型。 Local...
类型专门丢失了时区信息。如果没有时区信息,您将无法处理夏令时 (DST) 和其他异常情况。对于 Local...
类型,所有的日子都被假定为 24 小时,这在不同时区的现实生活中是不正确的。而是使用 Java 中的 ZonedDateTime
类型,以及接近 SQL 标准的 TIMESTAMP WITH TIME ZONE
问题的其余部分让我望而却步,因为你所说的“移位模板”和“零点”而让我迷失了方向。但我的直觉告诉我,由于不了解处理日期时间数据的有效方法,你工作太辛苦了。日期时间处理 很棘手。我建议做更多的研究,例如在 Stack Overflow 上搜索和阅读与“java date”相关的问题。
关于java - 将 TIMESTAMP (?) 用于 Java 和 MySQL 的日期时间持续时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37513145/
如果我错了,但身份验证 session 有 30 天的最大限制,请纠正我?如果是这种情况,有没有办法让我的服务器节点应用程序永远监听经过身份验证的 dataRef? 干杯, 旅行。 最佳答案 自 on
我目前正在阅读 book Continuos Delivery由 Humble/Farley 撰写,虽然里面的很多东西都是有道理的,但有一件事让我烦恼: 似乎作者只针对基于服务器的(单客户端?)应用程
好吧,我非常了解每个人对自制密码管理器的看法,但我希望得到帮助。 不用于实际使用,仅供学习。 我想知道,在 C++ 中如何拥有长期变量。或者真的,有什么长期的。 长期是什么意思?在下次运行 .exe
我在文本文件中有以下三行(最后 3 行): } } } 我想做的是做这样的事情: } } blablabla blablabla blabla
在 iOS 中,有没有一种简单的方法可以在每天的同一时间发送 10 天的推送通知?我不想向所有用户发送推送通知。我的应用程序的工作方式是,用户可以选择连续十天推送通知的时间。您有推荐的 API 吗?或
我正在努力寻找一种当前最先进的方法来处理频繁更新的通知(例如每 3 分钟一次)。似乎在较新的 Android 版本中内置了如此多的电源效率调整(幸运的是!),我之前成功使用的方法(使用 Broadca
我不得不在一些糟糕的房地产网站上花费大量时间。我比较精通 CSS,并且可以(在 FireFox 中)“检查元素”并更改 CSS 以隐藏或缩小特定页面的华而不实的元素。但我想将此自定义 CSS 应用于特
目前正在研究如何使用 signalR 在处理文件时向用户呈现文件的进度报告。我正在使用 asp.net MVC 4。通过 Ajax 进行发布/获取时,我可以轻松获取状态更改。 因为我需要上传一个文件(
这个问题在这里已经有了答案: How can I round up the time to the nearest X minutes? (15 个答案) Is there a simple fun
我有一个 php 脚本,我想运行特定的时间(例如 5 分钟),但只能运行一次。对于 cron 作业,这将无限期地运行。还有别的办法吗? 最佳答案 处理这个问题的方法是: 当某些事件触发需要 cron
我弄乱了我的 apache 和 php.ini 文件,我网站的用户仍然提示该网站在很短的时间后或每次他们关闭并打开同一个浏览器时将他们注销。 我正在运行 Apache 和 PHP。 我应该进行哪些设置
如何查询今天的总和需要减去前一天的总和,每天持续一个月。 SELECT COUNT(DISTINCT member_profile.memberProfileNumber) FROM member_p
这个问题在这里已经有了答案: How do I add a delay in a JavaScript loop? (32 个答案) 关闭 8 年前。 我认为这个问题之前一定有人问过,但我找不到其他
用户在我的网站上注册后,我们会向他发送一封确认电子邮件。我想要的是 - 三天内每 24 小时为用户重新发送一次电子邮件。例如: user_table id , name, date_registere
最近我从 Codeigniter 换到了 Laravel,一切都很顺利,除了我遇到了 Session::flash 的问题。 当我创建新用户时,我收到成功消息,但它会持续 2 个请求,即使我没有通过验
如果有人能帮助我解决这个问题,我将非常感激。 我正在尝试针对 CPU 使用率 >= 80% 持续 30 分钟或更长时间创建 Azure 监视器警报 我已附上警报规则条件的屏幕截图。在“评估依据”下,聚
如果有人能帮助我解决这个问题,我将非常感激。 我正在尝试针对 CPU 使用率 >= 80% 持续 30 分钟或更长时间创建 Azure 监视器警报 我已附上警报规则条件的屏幕截图。在“评估依据”下,聚
希望大家平安 1。我的目标 我正在尝试模拟 3 天的真实情况。系统每天只能工作 8 小时。 我的目标是模型运行 8 小时,持续 3 天,以获得足够的数据进行分析。 2。我的问题 我有一个代理预约时间表
我需要在 8 小时内每 5 分钟调用一次函数。问题是它必须是同一天。例如,如果用户在 3/29 晚上 11:59 登录系统,而现在是 3/30 凌晨 12:01,则不应再调用该函数。 我知道如何每
我正在开发一个 React Native 应用程序,该应用程序使用 Firebase 的 Firestore 作为后端。现在,每次收到新消息时,我都会从 Firestore 获取所有消息并更新我的状态
我是一名优秀的程序员,十分优秀!