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

2022-09-04 23:48:29

我试图了解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: ...


答案 1

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

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


答案 2

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

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

它甚至会自动创建您的表,您只需说,完成。book1.insert()


推荐