一个SQLite3的小例子

                   写了一个比较简单的SQLite3的简单demo只实现了增加 更新 删除 获取全部数据  查找   数据库部分有详细注释    界面也比较简陋主要是实现一下数据库部分


资源地址:http://download.csdn.net/detail/decemberd/3899232

        


部分代码如下:

//获取document目录并返回数据库目录

- (NSString *)dataFilePath{

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectoryNSUserDomainMaskYES);

NSString *documentsDirectory = [paths objectAtIndex:0];

return [documentsDirectory stringByAppendingPathComponent:kFilename];

}


//创建,打开数据库

- (BOOL)openDB {

//获取数据库路径

NSString *path = [self dataFilePath];

//文件管理器

NSFileManager *fileManager = [NSFileManager defaultManager];

//判断数据库是否存在

BOOL find = [fileManager fileExistsAtPath:path];

//如果数据库存在,则用sqlite3_open直接打开(不要担心,如果数据库不存在sqlite3_open会自动创建)

if (find) {

NSLog(@"Database file have already existed.");

//打开数据库,这里的[path UTF8String]是将NSString转换为C字符串,因为SQLite3是采用可移植的C(而不是

//Objective-C)编写的,它不知道什么是NSString.

if(sqlite3_open([path UTF8String], &_database) != SQLITE_OK) {

//如果打开数据库失败则关闭数据库

sqlite3_close(self._database);

NSLog(@"Error: open database file.");

return NO;

}

//创建一个新表

[self createTestList:self._database];

return YES;

}

//如果发现数据库不存在则利用sqlite3_open创建数据库(上面已经提到过),与上面相同,路径要转换为C字符串

if(sqlite3_open([path UTF8String], &_database) == SQLITE_OK) {

//创建一个新表

[self createTestList:self._database];

return YES;

    } else {

//如果创建并打开数据库失败则关闭数据库

sqlite3_close(self._database);

NSLog(@"Error: open database file.");

return NO;

    }

return NO;

}


//创建表

- (BOOL) createTestList:(sqlite3*)db {

//这句是大家熟悉的SQL语句

char *sql = "create table if not exists testTable(ID INTEGER PRIMARY KEY AUTOINCREMENT, testID int,testValue text)";

sqlite3_stmt *statement;

//sqlite3_prepare_v2 接口把一条SQL语句解析到statement结构里去使用该接口访问数据库是当前比较好的的一种方法

NSInteger sqlReturn = sqlite3_prepare_v2(_database, sql, -1, &statement, nil);

//第一个参数跟前面一样,是个sqlite3 * 类型变量,

//第二个参数是一个 sql 语句。

//第三个参数我写的是-1,这个参数含义是前面 sql 语句的长度。如果小于0sqlite会自动计算它的长度(把sql语句当成以\0结尾的字符串)。

//第四个参数是sqlite3_stmt 的指针的指针。解析以后的sql语句就放在这个结构里。

//第五个参数我也不知道是干什么的。为nil就可以了。

//如果这个函数执行成功(返回值是 SQLITE_OK  statement 不为NULL ),那么下面就可以开始插入二进制数据。

//如果SQL语句解析出错的话程序返回

if(sqlReturn != SQLITE_OK) {

NSLog(@"Error: failed to prepare statement:create test table");

return NO;

}

//执行SQL语句

int success = sqlite3_step(statement);

//释放sqlite3_stmt 

sqlite3_finalize(statement);

//执行SQL语句失败

if ( success != SQLITE_DONE) {

NSLog(@"Error: failed to dehydrate:create table test");

return NO;

}

NSLog(@"Create table 'testTable' successed.");

return YES;

}


//插入数据

-(BOOL) insertTestList:(sqlTestList *)insertList {

//先判断数据库是否打开

if ([self openDB]) {

sqlite3_stmt *statement;

//这个 sql 语句特别之处在于 values 里面有个号。在sqlite3_prepare函数里,?号表示一个未定的值,它的值等下才插入。

static char *sql = "INSERT INTO testTable(testID, testValue) VALUES(?, ?)";

int success2 = sqlite3_prepare_v2(_database, sql, -1, &statement, NULL);

if (success2 != SQLITE_OK) {

NSLog(@"Error: failed to insert:testTable");

sqlite3_close(_database);

return NO;

}

//这里的数字123代表第几个问号,这里将两个值绑定到两个绑定变量

sqlite3_bind_int(statement, 1, insertList.sqlID);

sqlite3_bind_text(statement, 2, [insertList.sqlText UTF8String], -1SQLITE_TRANSIENT);


//执行插入语句

success2 = sqlite3_step(statement);

//释放statement

sqlite3_finalize(statement);

//如果插入失败

if (success2 == SQLITE_ERROR) {

NSLog(@"Error: failed to insert into the database with message.");

//关闭数据库

sqlite3_close(_database);

return NO;

}

//关闭数据库

sqlite3_close(_database);

return YES;

}

return NO;

}


//获取数据

- (NSMutableArray*)getTestList{

NSMutableArray *array = [NSMutableArray arrayWithCapacity:10];

//判断数据库是否打开

if ([self openDB]) {

sqlite3_stmt *statement = nil;

//sql语句

char *sql = "SELECT testID, testValue FROM testTable";

if (sqlite3_prepare_v2(_database, sql, -1, &statement, NULL) != SQLITE_OK) {

NSLog(@"Error: failed to prepare statement with message:get testValue.");

return NO;

}

else {

//查询结果集中一条一条的遍历所有的记录,这里的数字对应的是列值。

while (sqlite3_step(statement) == SQLITE_ROW) {

sqlTestList* sqlList = [[sqlTestList allocinit] ;

sqlList.sqlID    = sqlite3_column_int(statement,0);

char* strText   = (char*)sqlite3_column_text(statement, 1);

sqlList.sqlText = [NSString stringWithUTF8String:strText];

                [array addObject:sqlList];

[sqlList release];

}

}

sqlite3_finalize(statement);

sqlite3_close(_database);

}

return [array retain];

}


//更新数据

-(BOOL) updateTestList:(sqlTestList *)updateList{

if ([self openDB]) {

//我想下面几行已经不需要我讲解了,嘎嘎 

sqlite3_stmt *statement;

//组织SQL语句

char *sql = "update testTable set testValue = ?  WHERE testID = ?";

//SQL语句放入sqlite3_stmt

int success = sqlite3_prepare_v2(_database, sql, -1, &statement, NULL);

if (success != SQLITE_OK) {

NSLog(@"Error: failed to update:testTable");

sqlite3_close(_database);

return NO;

}

//这里的数字123代表第几个问号。这里只有1个问号,这是一个相对比较简单的数据库操作,真正的项目中会远远比这个复杂

//当掌握了原理后就不害怕复杂了

sqlite3_bind_text(statement, 1, [updateList.sqlText UTF8String], -1SQLITE_TRANSIENT);

sqlite3_bind_int(statement, 2, updateList.sqlID);

//执行SQL语句。这里是更新数据库

success = sqlite3_step(statement);

//释放statement

sqlite3_finalize(statement);

//如果执行失败

if (success == SQLITE_ERROR) {

NSLog(@"Error: failed to update the database with message.");

//关闭数据库

sqlite3_close(_database);

return NO;

}

//执行成功后依然要关闭数据库

sqlite3_close(_database);

return YES;

}

return NO;

}

//删除数据

- (BOOL) deleteTestList:(sqlTestList *)deletList{

if ([self openDB]) {

sqlite3_stmt *statement;

//组织SQL语句

static char *sql = "delete from testTable  where testID = ? and testValue = ?";

//SQL语句放入sqlite3_stmt

int success = sqlite3_prepare_v2(_database, sql, -1, &statement, NULL);

if (success != SQLITE_OK) {

NSLog(@"Error: failed to delete:testTable");

sqlite3_close(_database);

return NO;

}

//这里的数字123代表第几个问号。这里只有1个问号,这是一个相对比较简单的数据库操作,真正的项目中会远远比这个复杂

//当掌握了原理后就不害怕复杂了

sqlite3_bind_int(statement, 1, deletList.sqlID);

sqlite3_bind_text(statement, 2, [deletList.sqlText UTF8String], -1SQLITE_TRANSIENT);

//执行SQL语句。这里是更新数据库

success = sqlite3_step(statement);

//释放statement

sqlite3_finalize(statement);

//如果执行失败

if (success == SQLITE_ERROR) {

NSLog(@"Error: failed to delete the database with message.");

//关闭数据库

sqlite3_close(_database);

return NO;

}

//执行成功后依然要关闭数据库

sqlite3_close(_database);

return YES;

}

return NO;

}

//查询数据

- (NSMutableArray*)searchTestList:(int)searchID{

NSMutableArray *array = [NSMutableArray arrayWithCapacity:10];

//判断数据库是否打开

if ([self openDB]) {

sqlite3_stmt *statement = nil;

//sql语句

char *sql = "SELECT testID, testValue FROM testTable WHERE testID = ?";

if (sqlite3_prepare_v2(_database, sql, -1, &statement, NULL) != SQLITE_OK) {

NSLog(@"Error: failed to prepare statement with message:search testValue.");

return NO;

}

else {

sqlite3_bind_int(statement, 1, searchID);

//查询结果集中一条一条的遍历所有的记录,这里的数字对应的是列值。

while (sqlite3_step(statement) == SQLITE_ROW) {

sqlTestList* sqlList = [[sqlTestList allocinit] ;

sqlList.sqlID    = sqlite3_column_int(statement,0);

char* strText   = (char*)sqlite3_column_text(statement, 1);

sqlList.sqlText = [NSString stringWithUTF8String:strText];

                [array addObject:sqlList];

[sqlList release];

}

}

sqlite3_finalize(statement);

sqlite3_close(_database);

}

return [array retain];

}





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值