gpt4 book ai didi

Java currentTimeMillis() 函数与特殊日期的区别 - MySQL?

转载 作者:行者123 更新时间:2023-11-29 14:45:53 28 4
gpt4 key购买 nike

我的数据库中有 50000 条这样的 XML 记录:

<?xml version="1.0" encoding="UTF-8"?>
<root>
<urlMD5>11ca7070ad6eb3180c53281e7b597976</urlMD5>
<date>
<year>2011</year>
<month>8</month>
<day>6</day>
<h>19</h>
<m>26</m>
<s>40</s>
</date>
<enc>utf-8</enc>
</root>

如您所见,我以分隔格式保存了日期。现在我需要提取这些天的 currentTimeMillis() 并将其保存到新字段中的数据库中。因此我可以轻松地将它们与当前的 currentTimeMillis() 进行比较,并找出最近两天存储了哪些文档。例如:

int ct = currentTimeMillis();

Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/crawler?" + "user=root&password=&useUnicode=true&characterEncoding=UTF-8");
Statement stat = conn.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM DBName WHERE ct - 60 * 60 * 24 * 2 > timeField");

而且因为我想多次使用这个字段,所以我想使用一个简单的查询,并且不想每次都提取 XML 格式。

问题是 currentTimeMillis() 函数计算从 1970 年 1 月 1 日开始的 currentTimeMillis,我需要用我的数据计算同样的事情。我用之前用来存储 XML 数据的相同代码编写了以下代码,以确保我是否可以做到这一点:

int s = 0;
s += (Calendar.getInstance().get(Calendar.YEAR) - 1970) * 60 * 60 * 24 * 365;
s += (Calendar.getInstance().get(Calendar.MONTH)) * 60 * 60 * 24 * 31;
s += (Calendar.getInstance().get(Calendar.DAY_OF_MONTH) * 60 * 60 * 24);
s += (Calendar.getInstance().get(Calendar.HOUR_OF_DAY) * 60 * 60);
s += (Calendar.getInstance().get(Calendar.MINUTE) * 60);
s += (Calendar.getInstance().get(Calendar.SECOND));
System.out.println(s);
System.out.println(System.currentTimeMillis() / 1000);

但是结果不一样:

1312313680
1312643080

原因之一是不是每个月都有 31 天。

无论如何,我需要帮助找出如何计算具有特殊日期而不是当前日期的 currentTimeMillis ?

我应该提到我正在使用 mysql,所以也许我可以以特殊格式保存日期,以便与 SQL 查询进行比较?

最佳答案

使用Calendar的set方法:

Calendar c = Calendar.getInstance();
c.set(Calendar.YEAR, year);
c.set(Calendar.MONTH, month);

等等

然后使用c.getTime().getTime()提取毫秒数。

关于Java currentTimeMillis() 函数与特殊日期的区别 - MySQL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6967837/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com