java - Android SQLite : Convert long to Date and back

标签 java android sqlite date

我有一个简单的待办事项应用程序,其中每个“待办事项”都有标题、描述、完成状态、创建日期和修改日期。

Todo.java

package com.anna.todos.models;

import java.util.Date;

public class Todo {
    private long id;
    private String title;
    private String text;
    private boolean done;
    private Date createdDate;
    private Date modifiedDate;

    public Todo() {
    }

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }

    public boolean isDone() {
        return done;
    }

    public void setDone(boolean done) {
        this.done = done;
    }

    public Date getCreatedDate() {
        return createdDate;
    }

    public void setCreatedDate(Date createdDate) {
        this.createdDate = createdDate;
    }

    public Date getModifiedDate() {
        return modifiedDate;
    }

    public void setModifiedDate(Date modifiedDate) {
        this.modifiedDate = modifiedDate;
    }
}

创建日期和修改日期以整数形式存储在 SQLite 数据库中。当我从数据库中获取它们时,我希望能够将它们正确地转换为 Date 对象,当我去保存待办事项时,我希望能够获取这些 Date 对象的整数或长等价物。 (这是根据另一个 StackOverflow post 的建议完成的)。

以下是我用来从数据库获取日期的代码:

    createdDate = new Date(cursor.getInt(4) * 1000);
    modifiedDate = new Date(cursor.getInt(5) * 1000);

并保存日期......

    createdDate = Calendar.getInstance().getTime();
    values.put(DatabaseHelper.TODO_CREATED_DATE, createdDate.getTime() * 1000);

我现在的问题是创建日期和修改日期没有正确转换。以下是从数据库加载日期的调试语句:

04-29 09:21:35.649: I/TodoEditActivity(3954): populateFields() => 创建日期=01 Jan 1970 10:33:01 04-29 09:21:35.649: I/TodoEditActivity(3954): populateFields() => moddedDate=01 Jan 1970 10:34:19

以及保存日期的调试语句:

04-29 09:22:00.653: I/TodoEditActivity(3954): saveTodo() => 创建日期=01 Jan 1970 10:33:01 04-29 09:22:00.653: I/TodoEditActivity(3954): saveTodo() => moddedDate=2012 年 4 月 29 日 09:22:00

我应该采取什么措施来解决这个问题?

最佳答案

我怀疑数据库中存储的createdDate的值为0(或一个小值)。尝试将变量设置为cursor.getInt(4) 并对其进行调试,以便您可以验证该值是否为您提供了当前日期。如果您使用 Date.getTime() 或 Calendar.getTimeInMillis(),则不需要乘以 1000。

关于java - Android SQLite : Convert long to Date and back,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10368555/

相关文章:

java - 未找到 Conexion 类

java - 垃圾收集器如何处理 Java 中的原始数据类型?

java - 如何通过另一个fragment中的onClick调用一个fragment中的方法?

java - Spring Security - 无效的列索引异常

java - 如何使用 JNI 在 C++ 中创建 Java 对象?

php - 如何在 PHP 类中使用 sql 查询解析 json 数据?

c# - 在 Windows 中的两个不同应用程序之间共享 sqlite 数据库

android - 需要命令行来使用 adb 启动 Web 浏览器

android - 在屏幕上均匀分布 TextView,并左右对齐

node.js - 在 Windows 上为 Electron 应用程序安装 npm sqlite3