我的数据库中有 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/