Develop
2013.04.23 17:13
[ios] Objective-C에서 SQLite 사용하기..
조회 수 14580 댓글 0
첨부 '4' |
---|
먼저 프로젝트를 windows based 로 생성합니다.
그다음에 아래와 같이 프레임워크를 우클릭하여 Add -> Existing Frameworks...을 선택합니다.
그러면 창이 하나 나올텐데 여기에서 libsqlite3.0.dylib를 선택하여 Add버튼을 클릭합니다.
간단하게 작업은 AppDelegate.m 파일에서만 하도록하겠습니다.
먼저 import 부분에 아래 구문을 추가합니다.
#import <sqlite3.h>
그 다음 아래 메소드에 코드를 추가합니다.
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { //도큐먼트 디렉토리 위치를 얻는다. NSString *documentsDirectory = [NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0]; //도큐먼트 위치에 db.sqlite명으로 파일패스 설정 NSString *filePath = [documentsDirectory stringByAppendingPathComponent:@"db.sqlite"]; //데이터베이스를 연결한다. //해당 위치에 데이터베이스가 없을경우에는 생성해서 연결한다. sqlite3 *database; if (sqlite3_open([filePath UTF8String], &database) != SQLITE_OK) { sqlite3_close(database); NSLog(@"Error"); } /* 테이블 생성 */ char *sql = "CREATE TABLE IF NOT EXISTS test (no INTEGER PRIMARY KEY NOT NULL, name VARCHAR)"; //sqlite3_exec 쿼리문을 실행할 수 있다. if (sqlite3_exec(database, sql, nil,nil,nil) != SQLITE_OK) { sqlite3_close(database); NSLog(@"Error"); } /* insert or update */ sqlite3_stmt *insertStatement; char *insertSql = "INSERT or REPLACE INTO test (no,name) VALUES(?,?)"; //프리페어스테이트먼트를 사용 if (sqlite3_prepare_v2(database, insertSql, -1, &insertStatement, NULL) == SQLITE_OK){ //?에 데이터를 바인드 sqlite3_bind_int(insertStatement, 1, 1); sqlite3_bind_text(insertStatement, 2, [@"test name" UTF8String], -1, SQLITE_TRANSIENT); // sql문 실행 if (sqlite3_step(insertStatement) != SQLITE_DONE) { NSLog(@"Error"); } } /* select */ sqlite3_stmt *selectStatement; char *selectSql = "SELECT no, name FROM test"; if (sqlite3_prepare_v2(database, selectSql, -1, &selectStatement, NULL) == SQLITE_OK) { // while문을 돌면서 각 레코드의 데이터를 받아서 출력한다. while (sqlite3_step(selectStatement)==SQLITE_ROW) { int no = sqlite3_column_int(selectStatement, 0); NSString *name = [NSString stringWithUTF8String: (char *)sqlite3_column_text(selectStatement, 1) ]; NSLog(@"no : %i, name : %@",no,name); } } //statement close sqlite3_finalize(insertStatement); sqlite3_finalize(selectStatement); //db close sqlite3_close(database); [window makeKeyAndVisible]; return YES; }
코드는 간략하게 주석을 달았으니 쉽게 이해할 수 있을 꺼라 생각합니다.
혹시 궁금하신 점있으시면 댓글달아주세요.
제가 아는 범위 또는 찾아볼 수 있는 범위안에서 설명해드리겠습니다.
실행을 하면 디버그콘솔창에 아래와 같은 결과가 나옵니다.
참고로 디버그 콘솔창은 커맨드키 + 쉬프트 + r 입니다.
그리고 소스도 올려드리겠습니다.
(별거는 없습니다 ;;)
[출처] 아이폰에서 sqlite사용하기(초간단 예제)|작성자 만쓰
[출처] http://blog.naver.com/rlarlaks21c/50097250975
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
525 | Develop | [winmobile] 윈도우 모바일 간단한 테스트 코드 ㅋㅋ | hooni | 2013.04.23 | 17120 |
524 | Develop | [ios] iOS 4.0 beta 에서 3.1.3으로 다운그레이드 하는 법 | hooni | 2013.04.23 | 37543 |
523 | Develop | [c] 메시지큐(Message Queue) 설명.. (joinc) | hooni | 2013.04.23 | 14302 |
522 | Develop | [android] 단일 Thread 환경의 안드로이드에서 Handler를 사용 | hooni | 2013.04.23 | 26576 |
521 | Develop | [android] 점심 해결 앱 소스 코드 ㅋㅋ | hooni | 2013.04.23 | 76497 |
520 | Develop | [ios] 한샘 카달로그 앱 소스 (아이폰용) | hooni | 2013.04.23 | 10922 |
519 | Develop | [android] 화면 전환(가로/세로)시 설정 | hooni | 2013.04.23 | 43427 |
518 | Develop | [android] 멀티터치(Multi touch) 부분 구현 ㅋㅋ | hooni | 2013.04.23 | 27471 |
517 | Develop | [html] HTML5 튜토리얼 링크 ㅋㅋ | hooni | 2013.04.23 | 12826 |
516 | Develop | [android] 해상도 관련 팁 (dip -> pixel 변환) | hooni | 2013.04.23 | 15368 |
515 | Etc | [ios] 아이폰 개발 따라하기 ㅋㅋㅋ | hooni | 2013.04.23 | 23345 |
514 | Develop | [android]개발 가이드 및 한글화 문서 | hooni | 2013.04.23 | 47563 |