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

标签 java mysql datetime

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

相关文章:

java - 即使在一个命令中也会出现线程并发问题吗?

mysql - #1111 - 组函数使用无效 - MYSQL

java - 减去天数而不影响时间

c# - 日期时间字符串格式和 CultureInfo

java - 如何在 JPQL 中按 SUM() 排序

java - 如何使用 JPA2 注释将结果限制为 Activity 记录

java - Android中的mp3标题读取问题

mysql - 有没有办法在 MySQL/Rails 中为单个查找强制区分大小写?

mysql - Like语句的缓存和加速解决方案

c# - 为什么 DateTime 基于 Ticks 而不是毫秒?