java - Android无法将日期时间写入sqlite数据库

标签 java android sqlite datetime

我在我的应用中使用 Google Tasks API。我的应用程序中的字段之一“截止日期”requires a DateTime object 。我使用 Android datepicker dailog 和 EditText View 来捕获截止日期,然后将用户输入转换为日期时间格式。当我尝试写入 SQLite 数据库时,出现以下异常。

Error inserting due=2015-06-14T15:58:38.572-04:00 title=Test app _id=TaskId0.07429873487580996 status=needsAction notes=Test write
    android.database.sqlite.SQLiteException: table tasks has no column named due (code 1): , while compiling: INSERT INTO tasks(due,title,_id,status,notes) VALUES (?,?,?,?,?)

这很令人困惑,因为我确实定义了一个名为“due”的列。日志中还有另一个异常。

06-14 15:58:38.607  15395-15395/com.github.idclark.forgetmenot E/EDITFRAGMENT﹕ null
    java.text.ParseException: Unparseable date: "06/14/15" (at offset 8)
            at java.text.DateFormat.parse(DateFormat.java:579)
            at com.github.idclark.forgetmenot.EditFragment.getTaskDueDate(EditFragment.java:64)

架构定义为

public static final class TaskEntry implements BaseColumns {

        public static final String TABLE_NAME = "tasks";
        public static final String COLUMN_TASK_ID = "_id";
        public static final String COLUMN_TASK_TITLE = "title";
        public static final String COLUMN_TASK_UPDATED = "updated";
        public static final String COLUMN_TASK_SELFLINK = "selfLink";
        public static final String COLUMN_TASK_PARENT = "parent";
        public static final String COLUMN_TASK_POSITION = "position";
        public static final String COLUMN_TASK_NOTES = "notes";
        public static final String COLUMN_TASK_STATUS = "status";
        public static final String COLUMN_TASK_DUE = "due";
        public static final String COLUMN_TASK_COMPLETED = "completed";
        public static final String COLUMN_TASK_DELETED = "deleted";
        public static final String COLUMN_TASK_HIDDEN = "hidden";

所以“到期”列确实存在。该表是由

创建的
@Override
    public void onCreate(SQLiteDatabase db) {

        //status must be either needsAction or completed

        final String CREATE_TASK_TABLE =
                "CREATE TABLE " + TaskEntry.TABLE_NAME + " (" +
                        TaskEntry._ID + " INTEGER PRIMARY KEY," +
                        TaskEntry.COLUMN_TASK_ID + "TEXT NOT NULL, " +
                        TaskEntry.COLUMN_TASK_TITLE + "TEXT NOT NULL, " +
                        TaskEntry.COLUMN_TASK_COMPLETED + "TEXT, " +
                        TaskEntry.COLUMN_TASK_NOTES + "TEXT, " +
                        TaskEntry.COLUMN_TASK_STATUS + "TEXT NOT NULL, " +
                        TaskEntry.COLUMN_TASK_DUE + "DATETIME, " +
                        TaskEntry.COLUMN_TASK_UPDATED + "DATETIME, " +
                        TaskEntry.COLUMN_TASK_PARENT + "TEXT, " +
                        TaskEntry.COLUMN_TASK_DELETED + "BOOLEAN, " +
                        TaskEntry.COLUMN_TASK_SELFLINK + "TEXT, " +
                        TaskEntry.COLUMN_TASK_POSITION + "TEXT, " +
                        TaskEntry.COLUMN_TASK_HIDDEN + "TEXT" + ")";

        db.execSQL(CREATE_TASK_TABLE);
    }

在此方法中进行截止日期转换。

public DateTime getTaskDueDate() {
    mDueDate = (EditText) getActivity().findViewById(R.id.task_due_date);
    return new DateTime(mDueDate.getText().toString());
}

最后将数据写入数据库

public boolean insertRow(Task task) {
        ContentValues values = new ContentValues();
        values.put(TaskContract.TaskEntry.COLUMN_TASK_STATUS, task.getStatus());
        values.put(TaskContract.TaskEntry.COLUMN_TASK_ID,task.getId());
        values.put(TaskContract.TaskEntry.COLUMN_TASK_TITLE,task.getTitle());
        values.put(TaskContract.TaskEntry.COLUMN_TASK_DUE, task.getDue().toString());
        values.put(TaskContract.TaskEntry.COLUMN_TASK_NOTES, task.getNotes());

        SQLiteDatabase db = this.getWritableDatabase();
        boolean createSuccessful = db.insert(TaskContract.TaskEntry.TABLE_NAME, null, values) > 0;
        db.close();
        return createSuccessful;
    }

我很困惑为什么此写入失败,并且 sql 声称没有“到期”列。即使存在解析异常,我也会在日志中看到时间戳。问题的一部分是我在将日期时间对象写入数据库之前调用 .toString() 吗?我没有太多的 sql 经验,并且真的很困惑如何处理这些异常。

最佳答案

对于 sqlite 问题,列名和类型之间需要有空格。例如,更改

TaskEntry.COLUMN_TASK_DUE + "DATETIME, " +

TaskEntry.COLUMN_TASK_DUE + " DATETIME, " +

您的几乎所有专栏都存在类似的问题。

修复CREATE TABLE SQL后,卸载并重新安装您的应用以重新创建数据库。

对于日期解析问题,请使用与您的数据匹配的日期格式。如果您需要详细帮助,请发布新问题。

关于java - Android无法将日期时间写入sqlite数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30834263/

相关文章:

java - DateTimeFormatter 个位数月份

java - holder.getAdapterPosition() 和 onBindViewHolder() 中构造函数的位置属性有什么区别

android - intel xdk app install 替换之前的apk

Android EditText AND SearchView : What are the main differences (except the design)?

java - Android SQLite,如何将Cursor变成字符串?

java - Eclipse Luna – AutoIndent 不一致

java - 从 Pig 获取字段模式的名称

android - 使用 Firebase 按键获取元素

sqlite - 根据列值动态更新SQLite行

mysql - Rails 切换数据库