'Table'에 해당되는 글 1건

  1. 2011.05.23 iPhone (아이폰) 개발시 DB를 위한 Sqlite3 다루기 (2)
2011.05.23 10:17

iPhone (아이폰개발시 DB를 위한 Sqlite3 다루기 (2)

 

개발환경 : Mac OS X 10.6.3, Simulator - 3.1.3

 

전편에서 작성한 sqlite3 파일을 어떻게 프로젝트에 넣고 사용하는지에 대한

설명을 했었다이번에는 여기에 테이블을 만들고 데이터를 집어 넣은후

그 내용을 가져와서 테이블 형태로 보여주는 프로그램을 구현해볼 것이다.

 

퀴즈 관련 테이블을 만든다.

CREATE TABLE "quiz" ("no" INTEGER PRIMARY KEY  AUTOINCREMENT  NOT NULL ,

"title" VARCHAR, "question" VARCHAR, "answer" VARCHAR, "level" VARCHAR)

 

이 테이블의 용도는 퀴즈 문제를 DB 에 넣어두고 문제풀이를 위한 어플을 만드는데

쓰일것이다아무것도 없으므로 샘플데이타를 집어넣어 준다.

[샘플 insert 쿼리문]

insert into quiz (title, question, answer, level) values ('title', '질문이다', '대답이다', '1')

insert into quiz (title, question, answer, level) values ('title2', '질문이다2', '대답이다2', '2')

insert into quiz (title, question, answer, level) values ('title3', '질문이다3', '대답이다3', '3')

 

데이터베이스 테이블에 매칭되는 모델클래스를 하나만든다. Subclass  NSObject 

된다.

테이블을 표시할 UIViewController 의 첫 로딩함수에 데이터베이스 생성과 데이터를

불러올 함수를 집어넣는다.

dbName 은 sqlite3 파일명을 말하며, dbPath 는 파일이 있는 위치를 저장한다.

quizs 는 quiz 모델객체가 저장될 클래스 이다그리고 함수가 2개 있는데

checkAndCreateDatabase 는 지정한 DB 파일명이 있는지 체크하고 있으면

그냥넘어가지만 없으면 에러를 출력하게 되어있다두번째 readFromDatabase

현재 quiz 테이블에 저장된 데이터를 모두 가져와 quizs 에 저장하는

임무를 맡고 있다.

 

MainXib.h

01 @interface MainXib : UIViewController {
02     NSString *path;
03     NSString *dbName;
04     NSString *dbPath;
05      
06     NSMutableArray *quizs;
07 }
08  
09 @property(nonatomic, retain)NSMutableArray *quizs;
10  
11 - (void)checkAndCreateDatabase;
12 - (void)readFromDatabase;
13  
14 @end

UIViewController 을 상속받아 만든 클래스이므로 화면이 로딩되면 처음으로

실행되는 함수가 viewDidLoad 이다여기에 데이터베이스를 체크하고

내용을 가져오는 내용이 들어가 있다.

MainXib.m

01 // Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
02 - (void)viewDidLoad {
03     dbName = @"success.sqlite";
04  
05     // Get the path to the documents directory and append the databaseName
06     NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,
07                                       NSUserDomainMask, YES);
08     NSString *documentsDir = [documentPaths objectAtIndex:0];
09     dbPath = [documentsDir stringByAppendingPathComponent:dbName];
10      
11     // Execute the "checkAndCreateDatabase" function
12     [self checkAndCreateDatabase];
13      
14     // Query the database for all animal records and construct the "animals" array
15     [self readFromDatabase];
16     [super viewDidLoad];
17 }

이제 테이블에 내용을 뿌려보도록 한다인터페이스 빌드에서 UITableView 를 넣고

델리게이트와 데이터소스를 연결 했다면 필수 구현함수 두가지를 작성해야한다

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section


아래의 내용은 그 두개의 함수에 구현된 내용이다소스를 보면 알겠지만

행에 집어넣을 데이터는 quiz 테이블의 title 필드이다.

01 // 셀을 넣는다
02 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
03     static NSString* cellIdentifier = @"cell";
04      
05     UITableViewCell* cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];
06      
07     // 이셀객체를 생성한다.
08     if (cell == nil) {
09         cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellIdentifier];
10         cell.accessoryType = UITableViewCellAccessoryDisclosureIndicator;
11     }
12      
13     QuizDTO *quiz = [quizs objectAtIndex:indexPath.row];
14     cell.textLabel.text = quiz.title;
15      
16     return cell;
17 }
18  
19 // 각테이블의 섹션을 리턴한다.
20 - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
21     return quizs.count;
22 }

소스가 다 작성이 되었다면 실행을 시켜본다첫번째 그림은 파이어폭스에서

select 쿼리를 날려 본 데이터이고 두번째는 프로그램을 돌렸을 때 화면에 표시된

내용이다
저작자 표시
신고
Posted by 우엉 여왕님!! ghostkyow

티스토리 툴바