android - 更新后 : "SQLiteException: unable to open database file"

标签 android

为什么应用更新到新版本后没有SQLite数据库?数据库怎么可能不再存在,即使它之前确实存在。

(使用安卓 2.3.3)

错误日志 为什么 SQLiteOpenHelper.getWritableDatabase() 会导致这个异常?它肯定会足够聪明地意识到“哦,数据库不存在,让我们创建它吧!”

请注意,据我所知,new SQLiteOpenHelper(context) 工作正常。但是,我不知道是否触发了onCreate()onUpgrade()

06-04 18:21:01.706 D/AndroidRuntime( 1280): Shutting down VM
06-04 18:21:01.706 W/dalvikvm( 1280): threadid=1: thread exiting with uncaught exception (group=0x40015560)
06-04 18:21:01.745 E/AndroidRuntime( 1280): FATAL EXCEPTION: main
06-04 18:21:01.745 E/AndroidRuntime( 1280): java.lang.ExceptionInInitializerError
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at myapp.com.MyActivity.onCreate(MyActivity.java:131)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.os.Handler.dispatchMessage(Handler.java:99)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.os.Looper.loop(Looper.java:130)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ActivityThread.main(ActivityThread.java:3683)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at java.lang.reflect.Method.invokeNative(Native Method)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at java.lang.reflect.Method.invoke(Method.java:507)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at dalvik.system.NativeStart.main(Native Method)
06-04 18:21:01.745 E/AndroidRuntime( 1280): Caused by: android.database.sqlite.SQLiteException: unable to open database file
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteDatabase.<init>(SQLiteDatabase.java:1849)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:820)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:854)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:847)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:547)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:118)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at myapp.com.storage.SQLiteStorage.<init>(SQLiteStorage.java:61)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     at myapp.com.storage.SQLiteStorage.<clinit>(SQLiteStorage.java:58)
06-04 18:21:01.745 E/AndroidRuntime( 1280):     ... 14 more
06-04 18:21:01.776 W/ActivityManager( 1002):   Force finishing activity myapp.com/.MyActivity

在我捕获异常“SQLiteException:无法打开数据库文件”之后,应用程序是否应该简单地尝试实例化另一个 SQLiteOpenHelper?

最佳答案

我已经让它可靠地工作(测试用例是强制关闭应用程序,删除它创建的 .db 文件,然后重新启动应用程序 - 这需要有根电话才能测试)。

解决方案:

SQLiteOpenHelper 对象(我的 SQLiteStorage 单例类中的嵌套类)需要从 Application.onCreate() 实例化,以便在服务和启动器 Activity 调用它们的 onCreate() 时表准备就绪

解释:

发生的事情是启动器 Activity 通过 Intent (也使用 SQLite 数据库进行存储)启动了服务,并且启动器 Activity 还启动了 SQLiteOpenHelper.onCreate()。但是,由于需要创建大量表,因此存在竞争条件,有时数据库在服务需要时尚未准备就绪。

关于android - 更新后 : "SQLiteException: unable to open database file",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10889456/

相关文章:

java - File.listFiles() 在 android 11 中返回 null

android - 禁用 GoogleMaps v2 View 以便它忽略所有触摸事件

android - 简单列表和使用数据库值的列表

android - 如何在电子邮件正文中添加图像

Android 从选项卡中的嵌套 Activity 使用 startActivityForResult。

android - 如何在覆盖 onItemClick() 的 setOnItemClickListener() 中访问 getLoaderManager()?

android - Roboguice、ADT 14+ 和 Android 库项目

java - 位图 getWidth 返回错误值

android - QT/QML,对话框打开后,后退按钮在 Android 上不起作用?

android - 从 Android WebView 中启动 map