我有一个简单的待办事项应用程序,每个'todo'都有标题,描述,完成状态,创建日期和修改日期。
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()=> createdDate = 01 Jan 1970 10:33:01 04-29 09:21:35.649:I / TodoEditActivity(3954):populateFields()=> modifiedDate = 01 Jan 1970 10:34:19
用于保存日期的调试语句:
04-29 09:22:00.653:I / TodoEditActivity(3954):saveTodo()=> createdDate = 01 Jan 1970 10:33:01 04-29 09:22:00.653:I / TodoEditActivity(3954):saveTodo()=> modifiedDate = 29 Apr 2012 09:22:00
我有什么办法可以解决这个问题吗?
答案 0 :(得分:0)
我怀疑存储在数据库中的createdDate的值是0(或小值)。尝试将变量设置为cursor.getInt(4)并对其进行调试,以便验证该值是否为您提供当前日期。如果使用Date.getTime()或Calendar.getTimeInMillis(),则不需要乘以1000。