在 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;
        }
    }
}

这是我主要活动中的代码

dbHelper = new DatabaseHelper(this);

dbHelper.insertBook("Harry Potter", "JK", "1000");
dbHelper.insertBook("Hamlet", "Shakespeare", "500");

Eclipse 告诉我 insertBook() 方法中有错误。它说有 no such table books: ... 。我不知道我在这里做错了什么。更令人沮丧的是,就在它完美运行前几分钟,然后(我认为)我删除了表,它只是出于某种原因再次创建它,即使这段代码自从我第一次创建它以来没有改变(我认为…)。

原文由 Mark D 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 333
2 个回答

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

稍后,当您希望在最终用户设备上的生产过程中向数据库添加新表,但保留现有数据时,用于添加新表、更改架构或升级数据的指定挂钩是 onUpgrade 你的方法 SQLiteOpenHelper

原文由 Thilo-Alexander Ginkel 发布,翻译遵循 CC BY-SA 3.0 许可协议

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

原文由 Faraz Ahmed 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题