2014-01-07 174 views
-1

当我使用cursor.getCount()或cursor.moveToFirst(),并没有记录被获取从DBSQLite数据库被损坏

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的多个实例可能会导致我的问题,如果我有两个实例同时更新相同的数据库文件。因此,我已经检查了每个db连接的实例,但没有任何帮助。 :(

我只是想删除数据库之前处理异常。

所以,球员请提出一些东西,解决了我的问题。

回答

0

如果数据库被破坏,你只需用备份替换数据库。您可以使用简单的文件复制粘贴方法来保持每天的备份

+1

感谢yushi,但这种方式将处理应用程序的进一步工作意味着下次打开应用程序:) – Gattsu