在我的应用程序中,我在很多情况下使用数据库,但有一种情况是我得到一个异常,并非每次都可以重现(但)。SQLiteException:不是一个错误
这只发生在操作系统版本2.3.7和2.1-update-1上。
代码:
public void removeOldOccurrences() {
SQLiteDatabase db = dbHelper.getWritableDatabase();
Long oldTime = System.currentTimeMillis() - VALID_OCCURRENCE_TIME;
String query = "";
try {
query = "DELETE FROM " + LOCATIONS_TABLE + " WHERE not ("
+ REMEMBERED_FIELD + "=1) " + "and (" + LAST_FIELD + "<"
+ oldTime + ");";
db.execSQL(query);
} catch (Exception e) {
Log.e(TAG, query);
e.printStackTrace();
} finally {
if (db != null) {
db.close();
}
}
}
的异常跟踪是:
android.database.sqlite.SQLiteException: not an error
at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
at android.database.sqlite.SQLiteDatabase.(SQLiteDatabase.java:1849)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:820)
at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:854)
at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:847)
at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:573)
at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:118)
请帮助。
嘿男人谢谢你的答案。我不认为这是真的,有两个原因:1.除了那几个案例(大部分是在2.3.7)之外,同一个查询每次都成功。 2.在您链接的同一文档中写入:“这些是一元前缀运算符: - +〜NOT”。除此之外,preetha说,并写道,当他说我得到了getWritableDatabase()方法的异常。 – Bush