我正在尝试了解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: ...
。我不知道我在这里做错了什么。让它更令人沮丧的是,在它工作完美之前只有几分钟,然后(我认为)我放弃了表,它只是因为某种原因再次创建它,即使这个代码自我第一次创建以来没有改变(我想......)。
答案 0 :(得分:38)
您的设备上有一个旧版本的数据库,它有(空)数据库,但没有books表。如果这是您的选择,只需卸载并重新安装该应用程序。
稍后,如果您想在最终用户设备上生产期间向数据库添加新表,但保留现有数据,则添加新表,更改架构或升级数据的指定挂钩是{{ 1}} onUpgrade
。
答案 1 :(得分:5)
我为此编写了一个ORM框架。 https://github.com/ahmetalpbalkan/orman
您可以使用SQLite轻松编写Android应用程序。它使用您的Java类(在本例中为Book)作为数据库表(实体)。
它甚至会自动创建您的表格,您只需说book1.insert()
,已完成。
答案 2 :(得分:2)
您必须卸载该应用程序,然后重新安装。它应该在那之后工作。
答案 3 :(得分:1)
试试这个 例如对于插入:
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);
***try
{
db.insert(TABLE_NAME, null, cv);
}
catch ( SQLiteException e)
{
onCreate(db);
db.insert(TABLE_NAME, null, cv);
}***
db.close();
return true;
} catch (Exception exp) {
exp.printStackTrace();
return false;
}
}
答案 4 :(得分:0)
如果出于某种原因,您删除了表,则可能需要删除数据库以强制应用程序正确地重新创建它。使用adb shell
并在/data/data/[package_name]/databases/
中查找数据库。你可以删除该文件。
答案 5 :(得分:0)
我遇到了这个问题,但清理项目并没有修复它
结果我通过了DATABASE_NAME
而不是TABLE_NAME
。
答案 6 :(得分:0)
确保调用onCreate
方法。创建多个表时,我也遇到了类似的问题。如果您创建一个单独的类,请确保首先清除应用程序的所有存储数据,然后再次运行它。它对我来说很好。
答案 7 :(得分:0)
由于表从数据库的一开始就存在,因此没有任何意义,因此我们尝试了不同的操作:
卸载应用
分段缓存/数据
更改数据库版本号
即使数据库已经存在,也要强制复制
答案 8 :(得分:-1)
db.execSQL(
"CREATE TABLE " + TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)"
);
删除表名后面的空格,应该是这样的。
db.execSQL(
"CREATE TABLE " + TABLE_NAME + "(id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)"
);
答案 9 :(得分:-1)
据我所知,您必须添加到要在Sqliteopenhelper class
中访问的外部数据库的路径,请参见以下代码段
public final static String DATABASE_PATH = "/data/data/com.example.shortcuts/databases/";
com.example.shortcuts=Your Package name