Android 데이터베이스 단일 SQLiteOpenHelper
1781 단어 Android
SQLiteOpenHelper 에서 MyDatabaseHelper 를 새로 만 듭 니 다.
volatile 을 사용 하여 MyDatabaseHelper 대상 을 설명 하고 getDBHelper()방법 으로 유일한 인 스 턴 스 를 가 져 옵 니 다.
private volatile static MyDatabaseHelper myDBHelper;
private MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
// , getDBHelper helper , helper
public static MyDatabaseHelper getDBHelper(Context context) {
if (myDBHelper == null) {
synchronized (MyDatabaseHelper.class) {
if (myDBHelper == null) {
myDBHelper = new MyDatabaseHelper(context, "MyWeather.db", null, DBVersion);
}
}
}
return myDBHelper;
}
데이터베이스 작업 이 필요 한 클래스 에서 MyDatabaseHelper.getDBHelper(context)방법 으로 유일한 helper 를 가 져 옵 니 다.이 helper 를 사용 하여 데이터 베 이 스 를 조작 합 니 다.
private SQLiteDatabase db;
...
db = MyDatabaseHelper.getDBHelper(getContext()).getWritableDatabase();
...
db.delete("SavedCity", "cityName = ?", new String[]{cityName});
물론 Helper 클래스 에서 데이터 베 이 스 를 가 져 오 는 방법 을 직접 설명 할 수도 있 습 니 다.
// private SQLiteDatabase mDB;
public SQLiteDatabase openWriteLink(){
if(mDB == null||!mDB.isOpen()){
mDB = myDBHelper.getWritableDatabase();
}
return mDB;
}
//
데이터 베 이 스 를 닫 는 방법 도 밝 혀 야 한다.
public void closeLink(){
if(mDB != null && mDB.isOpen()){
mDB.close();
mDB = null;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.