即使数据库版本更改并卸载了 Android 应用程序,SQLiteOpenHelper 也不会更新数据库

SQLiteOpenHelper not updating the DB even after DB version changed & uninstalled the Android App

我受困于我的 SQLiteOpenHelper class。
我创建了一个数据库,我所有来自数据库的数据都在应用程序上。
但后来我在 table 之一中添加了一列,现在它在 table.
中显示 no such column 我已经更新了数据库版本,也卸载了应用程序并在更新数据库版本后重新安装它,但它仍然显示相同的问题:no such column exists。

如果我评论 Column:type,那么它会显示 no such column named desc

我在新文件中重新创建了整个数据库结构,但仍然遇到同样的问题。

帮帮我,伙计们!

public static final String TABLE_RESTAURANTS = "restaurants";
public static final String COLUMN_LID = "id";
public static final String COLUMN_LNAME = "name";
public static final String COLUMN_LDESC = "desc";
public static final String COLUMN_LTYPE = "type";

在onCreate

String CREATE_TABLE_RESTAURANTS = "CREATE TABLE " + TABLE_RESTAURANTS + "("
            + COLUMN_LID + " INTEGER PRIMARY KEY," + COLUMN_LNAME + "TEXT,"
            + COLUMN_LDESC + "TEXT," + COLUMN_LTYPE + "TEXT" + ")";
db.execSQL(CREATE_TABLE_RESTAURANTS);

在升级中

db.execSQL("DROP TABLE IF EXISTS"+ TABLE_RESTAURANTS);
onCreate(db);

插入方式

public void insertRestaurantItsms(AppetiserData cartData)
{
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues contentValues = new ContentValues();
    contentValues.put(COLUMN_LNAME, cartData.getName());
    contentValues.put(COLUMN_LDESC, cartData.getDescription());
    contentValues.put(COLUMN_LTYPE, cartData.getCategory());

    // Inserting Row
    db.insert(TABLE_RESTAURANTS, null, contentValues);

    db.close(); // Closing database connection
}

获取方法

 public List<AppetiserData> getAllDatarl(){
    List<AppetiserData> dataList = new ArrayList<>();

    // Select All Query
    String selectQuery = "SELECT  * FROM " + TABLE_RESTAURANTS;

    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);
    cursor.moveToFirst();

    // looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        do {
            AppetiserData data = new AppetiserData();

            data.setName(cursor.getString(1));
            data.setDescription(cursor.getString(2));

            // Adding data to list
            dataList.add(data);
        } while (cursor.moveToNext());
    }

    return dataList;
}
String CREATE_TABLE_RESTAURANTS = "CREATE TABLE " + TABLE_RESTAURANTS + "("
        + COLUMN_LID + " INTEGER PRIMARY KEY," + COLUMN_LNAME + "TEXT,"
        + COLUMN_LDESC + "TEXT," + COLUMN_LTYPE + "TEXT" + ")";

您需要在列名和它们的类型之间添加 spaces 才能得到像 descTEXT.

这样的列
db.execSQL("DROP TABLE IF EXISTS"+ TABLE_RESTAURANTS);

EXISTS 和 table 名称之间需要 space。如果此 SQL 曾经被执行过,您会看到有关语法的异常。

当然你错过了 space 并且你也错过了在查询末尾放置分号。下面我已将这些更改添加到您的查询并发布。

创建Table查询:

String CREATE_TABLE_RESTAURANTS = "CREATE TABLE IF NOT EXISTS " + TABLE_RESTAURANTS + " ( "
            + COLUMN_LID + " INTEGER PRIMARY KEY, " + COLUMN_LNAME + " TEXT, "
            + COLUMN_LDESC + " TEXT, " + COLUMN_LTYPE + " TEXT " + ");";

掉落Table:

db.execSQL("DROP TABLE IF EXISTS "+ TABLE_RESTAURANTS);

希望这对您有所帮助:)