android sqlite 损坏,Android SQLite数据库已损坏

此链接完全描述了我的问题:

http://old.nabble.com/Android-database-corruption-td28044218.html#a28044218

现在大约有300人使用我的Android应用程序,每次使用此堆栈跟踪向服务器发送崩溃报告时:

android.database.sqlite.SQLiteDatabaseCorruptException: database disk image is malformed

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2596)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2621)

at android.app.ActivityThread.access$2200(ActivityThread.java:126)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1932)

at android.os.Handler.dispatchMessage(Handler.java:99)

at android.os.Looper.loop(Looper.java:123)

at android.app.ActivityThread.main(ActivityThread.java:4595)

at java.lang.reflect.Method.invokeNative(Native Method)

at java.lang.reflect.Method.invoke(Method.java:521)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)

at dalvik.system.NativeStart.main(Native Method) Caused by: android.database.sqlite.SQLiteDatabaseCorruptException: database disk image is malformed

at android.database.sqlite.SQLiteQuery.native_fill_window(Native Method)

at android.database.sqlite.SQLiteQuery.fillWindow(SQLiteQuery.java:75)

at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:295)

at android.database.sqlite.SQLiteCursor.getCount(SQLiteCursor.java:276)

at android.database.AbstractCursor.moveToPosition(AbstractCursor.java:171)

at android.database.AbstractCursor.moveToFirst(AbstractCursor.java:248)

结果是应用程序崩溃并且数据库中的所有数据都丢失了.

需要注意的一点是,每次我读取或写入数据库时​​,我都会得到一个新的SQLiteDatabase,并在完成后立即将其关闭.我这样做是为了防止这种腐败错误.

我还尝试使用单个静态对象同步所有数据库读取和写入,这似乎没有帮助.

这可能只是一个SQLite错误吗?

这是我的代码:

public class KeyValueTableAdapter extends BaseTableAdapter {

private String tableName;

private String keyColumnName;

private String valueColumnName;

public KeyValueTableAdapter(Context context, String tableName, String keyColumnName, String valueColumnName) {

super(context);

this.tableName = tableName;

this.keyColumnName = keyColumnName;

this.valueColumnName = valueColumnName;

}

protected String getStringValue(int key) {

Cursor cursor = null;

SQLiteDatabase db = null;

String value;

try {

db = dbOpenHelper.getReadableDatabase();

cursor = db.query(true, tableName, new String[] { valueColumnName }, keyColumnName + "=" + key, null, null, null, null, null);

if ((cursor.getCount() == 0) || !cursor.moveToFirst()) {

value = null;

} else {

value = cursor.getString(0);

}

} finally {

if (cursor != null) cursor.close();

if (db != null) db.close();

dbOpenHelper.close();

}

return value;

}

}

public abstract class BaseTableAdapter {

protected DbOpenHelper dbOpenHelper;

public BaseTableAdapter(Context context) {

this.dbOpenHelper = new DbOpenHelper(context, DatabaseSettings.DATABASE_NAME, null, DatabaseSettings.DATABASE_VERSION);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值