Views 2056 Votes 0 Comment 0
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print

객체와 이전 글(https://hooni.net/83716)에서 Activity에서 호출하여 사용하는 간단한 SQLite 예제를 소개했고,

이 단점을 보완하여 별도의 코드를 만들어 재사용할 수 있는 예제를 소개한다. (SQLiteOpenHelper)


# DBManager.java

import java.util.ArrayList;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.widget.Toast;
 
//DB를 총괄관리
public class DBManager {
 
    // DB관련 상수 선언
    private static final String dbName = "APinfo.db";
    private static final String tableName = "APinfo";
    public static final int dbVersion = 1;
 
    // DB관련 객체 선언
    private OpenHelper opener; // DB opener
    private SQLiteDatabase db; // DB controller
 
    // 부가적인 객체들
    private Context context;
 
    // 생성자
    public DBManager(Context context) {
        this.context = context;
        this.opener = new OpenHelper(context, dbName, null, dbVersion);
        db = opener.getWritableDatabase();
    }
 
    // Opener of DB and Table
    private class OpenHelper extends SQLiteOpenHelper {
 
        public OpenHelper(Context context, String name, CursorFactory factory,
                int version) {
            super(context, name, null, version);
            // TODO Auto-generated constructor stub
        }
 
        // 생성된 DB가 없을 경우에 한번만 호출됨
        @Override
        public void onCreate(SQLiteDatabase arg0) {
            // String dropSql = "drop table if exists " + tableName;
            // db.execSQL(dropSql);
 
            String createSql = "create table " + tableName + " ("
                    + "id integer primary key autoincrement, " + "SSID text, "
                    + "capabilities integer, " + "passwd text)";
            arg0.execSQL(createSql);
            Toast.makeText(context, "DB is opened", 0).show();
        }
 
        @Override
        public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
            // TODO Auto-generated method stub
        }
    }
 
    // 데이터 추가
    public void insertData(APinfo info) {
        String sql = "insert into " + tableName + " values(NULL, '"
                + info.getSSID() + "', " + info.getCapabilities() + ", '"
                + info.getPasswd() + "');";
        db.execSQL(sql);
    }
 
    // 데이터 갱신
    public void updateData(APinfo info, int index) {
        String sql = "update " + tableName + " set SSID = '" + info.getSSID()
                + "', capabilities = " + info.getCapabilities()
                + ", passwd = '" + info.getPasswd() + "' where id = " + index
                + ";";
        db.execSQL(sql);
    }
 
    // 데이터 삭제
    public void removeData(int index) {
        String sql = "delete from " + tableName + " where id = " + index + ";";
        db.execSQL(sql);
    }
 
    // 데이터 검색
    public APinfo selectData(int index) {
        String sql = "select * from " + tableName + " where id = " + index
                + ";";
        Cursor result = db.rawQuery(sql, null);
 
        // result(Cursor 객체)가 비어 있으면 false 리턴
        if (result.moveToFirst()) {
            APinfo info = new APinfo(result.getInt(0), result.getString(1),
                    result.getInt(2), result.getString(3));
            result.close();
            return info;
        }
        result.close();
        return null;
    }
 
    // 데이터 전체 검색
    public ArrayList<apinfo> selectAll() {
        String sql = "select * from " + tableName + ";";
        Cursor results = db.rawQuery(sql, null);
 
        results.moveToFirst();
        ArrayList<apinfo> infos = new ArrayList<apinfo>();
 
        while (!results.isAfterLast()) {
            APinfo info = new APinfo(results.getInt(0), results.getString(1),
                    results.getInt(2), results.getString(3));
            infos.add(info);
            results.moveToNext();
        }
        results.close();
        return infos;
    }
}


# Activity

DBManager manager = new DBManager(this);
manager.updateData(newInfo, index);
manager.insertData(newInfo);


Activity에서 DBManager를 통해 SQLite를 이용하는 샘플 코드이다.

DBManager 인스턴스를 생성하는 순간 DB가 오픈되고, 만약 해당 DB나 Table이 존재하지 않으면 OpenHelper()와 onCreate() 메소드에 의해 자동 생성된다.

DB가 오픈되면 생성한 DBManager 인스턴스를 이용하여 데이터의 추가/갱신/삭제/조회가 가능하다.


?

List of Articles
No. Category Subject Author Date Views
1061 System/OS [linux] 종료와 종료코드 확인(환경변수에서) hooni 2003.04.23 15538
1060 System/OS [linux] 셀 스크립트 if, for, case in.. hooni 2003.04.23 13684
1059 System/OS [linux] 스케쥴링 순서(nice) 변경하기 hooni 2003.04.23 12534
1058 System/OS [linux] 기존 환경설정 저장하면서 커널 컴파일.. hooni 2003.04.23 13456
1057 System/OS [linux] Proftpd 설치 가이드 hooni 2003.04.23 13019
1056 Develop [c] 간단한 자료구조(stack, queue, linked list) 구현 소스 6 file hooni 2003.04.23 10104
1055 Develop [c] 파일입출력, 링크리스트(linked list)를 이용한 주소록(도스용) 소스코드 1 file hooni 2003.04.23 11139
1054 Develop [c] 테트리스(Tetris) 게임(도스용) 소스코드 file hooni 2003.04.23 11465
1053 Develop [c] flooding 알고리즘 미로 찾기(도스용) 소스코드 9 file hooni 2003.04.23 12492
1052 Develop [jsp][php] 간단한 강좌 자료.. file hooni 2003.04.23 8098
1051 Develop [c] 학생명단 관리 프로그램 소스 ㅋㅋ 1 file hooni 2003.04.23 7759
1050 Develop [c] 근의 공식으로 2차방정식 풀기.. file hooni 2003.04.23 7762
1049 Develop [c] 이진트리(binary tree)의 운행.. hooni 2003.04.23 8253
1048 Develop [c] 이진트리(binary tree)의 특성 file hooni 2003.04.23 9596
1047 Develop [자료구조] 트리(tree) 용어정리 file hooni 2003.04.23 11056
1046 Develop [c] 농구팀 점수 산출 프로그램 소스 file hooni 2003.04.23 7370
Board Pagination Prev 1 ... 6 7 8 9 10 ... 74 Next
/ 74