簡體   English   中英

如何在Android中從sqlite數據庫存儲和檢索日期?

[英]How to store and retrieve Date from sqlite db in Android?

我將日期存儲在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歲的虛假時間。 我要去哪里錯了?

java.util.Date.getTime()返回自1970年開始(毫秒時間)以來的毫秒數。 SQLite可以處理Unix紀元時間,該時間是相同的值,但以秒表示(請參見java.util.Date.getTime() )。

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

您可以將值除以1000得到Unix風格的時代時間,並為SQLite的日期函數指定'unixepoch'(請參見SQLite時間和日期函數 ),例如:

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

如果您使用的是java.sql.Date ,則它是相同的(該類擴展了java.util.Date )。

但是,正如問題注釋中提到的323go一樣,只需直接按KEY_TIME排序即可,這將為您提供所需的排序順序。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM