오류 처리:java.lang.IllegalStateException: databases already closed
오늘 Android 기반 가져오기 2.x 버전 SDK 프로젝트, 실행 중 오류가 발생했습니다. 오류는 다음과 같습니다.
11-18 16:58:56.595:E/AndroidRuntime(22991): java.lang.RuntimeException: Unable to start servicexxx.xxxx.service.LocalService@41985638 with Intent {act=xxx.xxx.xxx.APP_SERVICE (has extras) }: java.lang.IllegalStateException:database/data/data/xxx.xxx.xxx/databases/xxx.db (conn# 0) already closed
데이터베이스 작업 부분에 문제가 있는 것으로 판단, 데이터베이스 작업 부분 파일 코드 DBHelper.java는 다음과 같습니다.
package org.yousee.utils;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
/**
*
*/
public class DBHelper extends SQLiteOpenHelper {
private Cursor c = null;
private static final String CREATE_TAB = "create table "
+ "music(_id integer primary key autoincrement,music_id integer,clicks integer," + "latest text)";
private static final String TAB_NAME = "list";
private SQLiteDatabase db = null;
public DBHelper(Context context, String name, CursorFactory factory,int version) {
super(context, name, factory, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
this.db = db;
db.execSQL(CREATE_TAB);
}
public void insert(ContentValues values){
SQLiteDatabase db = this.getWritableDatabase();
db.insert(TAB_NAME, null, values);
db.close();// this.close()
}
public void update(ContentValues values,int id){
SQLiteDatabase db = this.getWritableDatabase();
db.update(TAB_NAME, values, "music_id="+id, null);
db.close();// this.close()
}
public void delete(int id){
if (db == null){
db = getWritableDatabase();
}
db.delete(TAB_NAME, "music_id=?", new String[]{String.valueOf(id)});
}
public Cursor query(int id){
SQLiteDatabase db = getReadableDatabase();
c = db.query(TAB_NAME, null, "music_id=?", new String[]{String.valueOf(id)}, null, null, null);
db.close();// this.close()
return c;
}
public Cursor queryByClicks(){//
SQLiteDatabase db = getReadableDatabase();
c = db.query(TAB_NAME, null, null, null, null, null, "clicks desc");
return c;
}
public Cursor queryRecently(){//
SQLiteDatabase db = getReadableDatabase();
c = db.query(TAB_NAME, null, null, null, null, null, "latest desc");
return c;
}
public void close(){
if (db != null){
db.close();// this.close()
db=null;
}
if (c!=null){
c.close();
c=null;
}
}
@Override
public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
}
}
분석 결과 데이터베이스를 닫을 때 SQLiteDatabase를 직접 호출한 것으로 나타났습니다.close () 메서드.
오류의 구체적인 원인은 다음과 같습니다.
SQLiteDatabase를 호출하는 경우close()가 SQLiteOpenHelper를 대체합니다.close().그러면 SQLite OpenHelper는 helper를 통해 얻은 DB가 닫혔는지 (getReadable Database 또는 getWritable Database) 알지 못합니다.
요약:
1、SQLiteOpenHelper.close()는 비동기적이며 SQLiteDatabase는 비동기적입니다.close () 아니요.
2. 안드로이드가 제공하는 SQLite OpenHelper를 사용할 때 getReadable Database나 getWritable Database를 통해 얻은 것은 같은 대상이다. 유일한 것은 하드디스크가 부족하면 getWritable Database를 호출할 수 없고 getReadable Database만 호출할 수 있다는 것이다.
3. Android에서 제공하는 데이터베이스 인터페이스를 사용하여 데이터베이스 작업을 할 때는 Andoid의 규칙을 따라야 합니다.다중 스레드에서 주의해야 하기 때문에 대상을 대상으로 하는 습관을 기르고helper의close 방법으로 데이터베이스를 닫습니다.(누가 제공한 데이터는 누구의 방법으로 데이터를 조작한다)
인터넷에서 유사한 문제가 발견되었다.
http://androiddev.orkitra.com/?p=30756
http://stackoverflow.com/questions/6535908/android-sqlite-sqliteopenhelper-error-illegalstateexception-db-already-clo
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.