在SQLite Android中发现"没有这样的表"错误

Mar*_*k D 12 java sqlite android

我正在尝试学习SQLite数据库,但我真的很讨厌处理任何后端的东西,充满激情.我已经用一个看似简单的问题撞墙了.

这是我认为在DatabaseHelper课堂上很重要的代码

public class DatabaseHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "Library";

    public static final String TABLE_NAME = "books";
    public static final String TITLE = "title";
    public static final String AUTHOR = "author";
    public static final String ISBN = "isbn";

    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE " + TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)");
    }


    public boolean insertBook(String title, String author, String isdn) {

        try {
            SQLiteDatabase db = getWritableDatabase();

            ContentValues cv = new ContentValues();
            cv.put(TITLE, title);
            cv.put(AUTHOR, author);
            cv.put(ISBN, isdn);

            db.insert(TABLE_NAME, null, cv);
            db.close();

            return true;
        } catch (Exception exp) {
            exp.printStackTrace();

            return false;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我主要活动中的代码

dbHelper = new DatabaseHelper(this);

dbHelper.insertBook("Harry Potter", "JK", "1000");
dbHelper.insertBook("Hamlet", "Shakespeare", "500");
Run Code Online (Sandbox Code Playgroud)

Eclipse告诉我方法中有错误insertBook().它说有no such table books: ....我不知道我在这里做错了什么.让它更令人沮丧的是,在它工作完美之前只有几分钟,然后(我认为)我放弃了表,它只是因为某种原因再次创建它,即使这个代码自我第一次创建以来没有改变(我认为...).

Thi*_*kel 41

您的设备上有一个旧版本的数据库,它有(空)数据库,但没有books表.如果这是您的选择,只需卸载并重新安装该应用程序.

稍后,当您想在最终用户设备上生产期间向数据库添加新表时,但保留现有数据,添加新表,更改架构或升级数据的指定挂钩是您的onUpgrade方法SQLiteOpenHelper.


Ahm*_*gle 5

我为此编写了一个ORM框架.https://github.com/ahmetalpbalkan/orman

您可以使用SQLite轻松编写Android应用程序.它使用您的Java类(在本例中为Book)作为数据库表(实体).

它甚至可以自动创建您的表格,您只需说完book1.insert(),就完成了.


Far*_*med 5

您必须卸载该应用程序,然后重新安装它。在那之后它应该工作。