在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: ...