如何在Android中从sqlite db存储和检索日期?

时间:2013-08-12 16:51:47

标签: java android datetime

我将日期存储在Android中的sqlite数据库中,如下所示:

initialValues.put(KEY_TIME, time.getTime());

其中time是Date的实例(具有正确的时间),KEY_TIME是整数列。

存储后,当我使用如下查询检索它时:

String selectQuery = "SELECT  * FROM " + TABLE_NAME + " order  by date(" + KEY_TIME + ") DESC" ;

我从来没有先获得最近的数据。

我得到了近40岁的虚假时间。我哪里错了?

1 个答案:

答案 0 :(得分:1)

java.util.Date.getTime()返回自1970年开始(纪元时间)以来的毫秒数。 SQLite可以处理Unix纪元时间,它是相同的值,但以秒表示(参见java.util.Date.getTime())。

秒和毫秒的不匹配是您看到错误日期的原因。

您可以将值除以1000以获得Unix样式的纪元时间,并为SQLite的日期函数指定'unixepoch'(请参阅SQLite Time & Date Functions),例如:

SELECT date(KEY_TIME / 1000, 'unixepoch') FROM TABLE_NAME

如果您使用java.sql.Date它是相同的(该类扩展java.util.Date)。

但是,正如问题评论中提到的323go,只需直接按KEY_TIME排序,它将为您提供所需的排序顺序。