2012-06-04 3 views
1

왜 응용 프로그램이 새 버전으로 업데이트 된 후 SQLite 데이터베이스가 존재하지 않습니까? 이전에 존재 했더라도 데이터베이스가 더 이상 존재하지 않을 수 있습니다.업데이트 후 : "SQLiteException : 데이터베이스 파일을 열 수 없습니다"

(사용 안드로이드 2.3.3)

는 오류 로그 이유 SQLiteOpenHelper.getWritableDatabase()이 예외를 일으킬까요? 확실히 그것은 현실을 만들 수, 우 DB를 존재하지 않는 "실현 정도로 영리한 것하세요 new SQLiteOpenHelper(context)는 지금까지 내가 말할 수있는 OK 일한

참고. 그러나, 나는 촉발 된 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 

I 트랩을 제외하고 "SQLiteException : 데이터베이스 파일을 열 수 없습니다"후? 앱이 단순히 다른 SQLiteOpenHelper의 인스턴스를 시도해야 내가 들어 왔

+0

"데이터베이스 파일을 열 수 없음"이 반드시 데이터베이스가 더 이상 존재하지 않는다고 의미하지는 않습니다. 어떤면에서는 부패했을 수도 있습니다. 예외를 잡아두고'e.printStackTrace()'를 사용하여 나머지 예외를보십시오. 그것은 정말로 그것을 찾을 수 없다는 것을 말하고 있습니까? – Squonk

+0

'find/data -name * .db' 명령을 사용하고 응용 프로그램의 데이터베이스가 표시되지 않았다는 사실을 잊어 버렸습니다. –

+0

"앱이 업데이트되었습니다"라고 말하면 ... apk의 새로운 버전입니까? , 데이터베이스 업그레이드, 둘 다? – Squonk

답변

1

을 안정적으로 작업 (테스트 케이스는 강제로했다 응용 프로그램을 닫고 만든 .db 파일을 삭제 한 다음 응용 프로그램을 다시 시작하십시오. 이 테스트를 위해서는 뿌리깊은 전화기가 필요합니다).

솔루션 :

SQLiteOpenHelper 객체 Application.onCreate()에서 인스턴스화 할 필요가 (내 SQLiteStorage 싱글 클래스 내에서 중첩 클래스) 그래서 표는 서비스 및 실행 활동이라는 시간으로 준비가 그들의 에서 onCreate()의

설명 : 무슨 일이 있었는지

은 실행 활동 (또한 저장을 위해 SQLite는 DB를 사용) 의도을 통해 서비스와 L을 시작하다 auncher 활동도 SQLiteOpenHelper.onCreate()를 시작했습니다. 그러나 생성해야 할 테이블이 많기 때문에 경쟁 조건이 있었으며 때로는 데이터베이스가 서비스를 원할 때 준비되지 않았습니다.

+0

동일한 문제가 있지만 코드가 멀티 스레드가 아닙니다. 아직 해결책을 찾고있다. –

관련 문제