为什么我的Android数据库没有存储任何东西?

时间:2011-12-09 21:18:43

标签: android database sqlite database-administration

我正在开发一个也涉及数据库的Android应用程序,而且我遇到了一个非常烦人的错误。我正在研究一个从网上获取的例子。

下面的示例工作得很好(没有logcat错误)。但是,如果我尝试更改KEY字符串的内容,它将停止工作。

E.g。如果我改变         KEY_LOCATION =“title”到KEY_LOCATION =“title1”,整个数据库崩溃。

到目前为止,我还尝试增加数据库版本号但没有成功。任何帮助都将非常感激。

    private static final String DATABASE_NAME="data";
private static final String DATABASE_TABLE="reminders";
private static final int DATABASE_VERSION=4;

public static final String KEY_LOCATION="title1";
public static final String KEY_BODY="body";
public static final String KEY_DATE_TIME="date_time_value";
public static final String KEY_ROW_ID="_id";

private DatabaseHelper mDbHelper;
private SQLiteDatabase db;

private static final String DATABASE_CREATE =
        "create table " + DATABASE_TABLE + " ( "+
                KEY_ROW_ID+ " integer primary key autoincrement, "+
                KEY_LOCATION+ " text not null, "+
                KEY_BODY+" text not null, "+
                KEY_DATE_TIME+ " text not null);";

private Context mContext;

public DbAdapter(Context c){
    mContext=c;
}


public DbAdapter open() throws android.database.SQLException{
    mDbHelper=new DatabaseHelper(mContext);
    db=mDbHelper.getWritableDatabase();
    return this;
}

public void close(){
    mDbHelper.close();
}

public long createReminder(String title, String body, String dateTime){
    ContentValues initialValues = new ContentValues();
    initialValues.put(KEY_LOCATION, title);
    initialValues.put(KEY_BODY, body);
    initialValues.put(KEY_DATE_TIME, dateTime);

    return db.insert(DATABASE_TABLE, null, initialValues);

}

..................

这些是我得到的错误:

    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:64)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.database.sqlite.SQLiteProgram.compileSql(SQLiteProgram.java:146)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1737)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1610)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at pirelli.app.dbadapter.PirelliDbAdapter.createReminder(PirelliDbAdapter.java:55)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at pirelli.app.dbadapter.PirelliDbAdapter.createReminder(PirelliDbAdapter.java:55)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at pirelli.app.HSEActivity$1.onClick(HSEActivity.java:149)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.view.View.performClick(View.java:3110)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.view.View$PerformClick.run(View.java:11934)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.os.Handler.handleCallback(Handler.java:587)
    11-29 21:43:02.722: E/SQLiteDatabase(2150):     at android.os.Handler.dispatchMessage(Handler.java:92)

2 个答案:

答案 0 :(得分:1)

尝试更改。

private static final String DATABASE_TABLE="reminders";

private static final String DATABASE_TABLE="reminders2";

答案 1 :(得分:1)

当您尝试添加此新数据时,很可能在早期测试中数据库中已存在数据。

由于您使用不同的键(title而不是title1)添加了该数据,因此数据库表期望您按照title - body - date_time_value - _id序列插入数据。

在插入具有不同列名的新数据之前,您需要删除旧数据库,或者通过将表名更改为reminders2来创建不同的表,如Coder所说。

要删除数据库,请调用此方法:

public void dropTable() {
        db.execSQL("DROP TABLE IF EXISTS reminders");
    }