を使用してAndroidアプリケーションを作成していsqlite
ます。多くの活動と1つのサービスがあります。複数のスレッドからDBを使用しています。で完全に機能しAndroid 2.X
ますが、実行するAndroid 3.X
と常にこのエラーがスローされ、Force Close
:
05-04 22:17:04.815: I/SqliteDatabaseCpp(8774): sqlite returned: error code = 5, msg = database is locked, db=/data/data/xxx/databases/im
05-04 22:17:04.815: E/SqliteDatabaseCpp(8774): sqlite3_open_v2("/data/data/xxx/databases/im", &handle, 6, NULL) failed
05-04 22:17:04.835: E/SQLiteDatabase(8774): Failed to open the database. closing it.
05-04 22:17:04.835: E/SQLiteDatabase(8774): android.database.sqlite.SQLiteDatabaseLockedException: database is locked
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:983)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:956)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:1021)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:790)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:221)
05-04 22:17:04.835: E/SQLiteDatabase(8774): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:149)
なぜそれが起こるのか、そしてそれをどのように解決するのか誰もが知っていますか?
私はインターネットで調査しました、そしてほとんどの人はアドバイスします:
- アプリケーションにのみ1つのDB接続を使用します。それを確実にする方法は?サービスとアクティビティの両方でDB接続を共有したいと思います。パブリック静的DB変数を作成することでそれを行う必要がありますか?
- ContentProvider-コードで複雑なSQLステートメントを使用しています(いくつかのテーブルの結合、一時テーブルなど)。これらの複雑なSQLステートメントをContentProviderで実行することは可能ですか?
みんなありがとう。最後に、(1)は私にとってはうまくいきます。しかし、Android2.Xにこの問題がないのはなぜだろうと思います。