IOS开发学习笔记:iOS数据库编程

移动开发 iOS
IOS开发学习笔记iOS数据库编程是本文要介绍的内容,SQLite3是一个轻量级的数据库,完全使用C语言编写,使用简单方便。它是一个嵌入到程序进程的数据库,和其他一些数据库(MySQL,MS SQL)不同,它没有独立的进程。

IOS开发学习笔记iOS数据库编程是本文要介绍的内容,主要是来了解IOS开发中的数据库的学习,具体内容来看详解。在IOS开发过程中常常会用到数据库,而SQLite3iPhone中支持的数据库。下面简单介绍一下iPhone中SQLite3数据库的用法:

SQLite3是一个轻量级的数据库,完全使用C语言编写,使用简单方便。它是一个嵌入到程序进程的数据库,和其他一些数据库(MySQL,MS SQL)不同,它没有独立的进程。

1、打开数据库

首先声明一个数据库变量

  1. sqlite3 *db = NULL

每一个SQLite3都是一个文件,打开一个数据库只需要调用一次sqlite3_open函数:

  1. SQLITE_API int sqlite3_open(  
  2. const char *filename,   /* Database filename (UTF-8) */  
  3. sqlite3 **ppDb          /* OUT: SQLite db handle */  
  4. ); 

filename是数据库的路径,ppDb是指向返回的sqlite3数据库,返回SQLITE3_OK则表示正常。比如我们打开Document目录下的“Test.db”数据库:

  1. int result = sqlite3_open([dbPath UTF8String], &db);  
  2. NSAssert(result==SQLITE_OK, @”Can’t open database %@”, dbPath); 

注意:如果dbPath路径下的数据库不存在,那么打开这个数据库将会创建一个空的数据库。

2、执行SQL语句

SQLite3有3种执行SQL语句的方法:

通过sqlite3_exec()函数,适用于执行(非查询)语句:如CREATE TABLE、INSERT,REPLACE,DELETE等。

  1. SQLITE_API int sqlite3_exec(  
  2. sqlite3*,                                  /* An open database */  
  3. const char *sql,                           /* SQL to be evaluated */  
  4. int (*callback)(void*,int,char**,char**),  /* Callback function */  
  5. void *,                                    /* 1st argument to callback */  
  6. char **errmsg                              /* Error msg written here */  
  7. ); 

比如我们要创建一个表示个人(person)的表,就可以使用sqlite3_exec()函数。person表中包括名字(name)、性别(gender)、年龄(age)和生日(birthday)这几个字段。代码如下:

  1. char *errmsg = NULL;  
  2. result = sqlite3_exec(db, “CREATE TABLE person (”  
  3. “name TEXT,”  
  4. “gender INTEGER,”  
  5. “age INTEGER,”  
  6. “birthday DATE)”, NULL, NULL, &errmsg);  
  7. NSAssert(result==SQLITE_OK, @”Can’t CREATE TABLE: %s”, errmsg); 

通过sqlite3_get_table()函数,适用于查询语句SELECT。由于此函数返回一个字符串数组,因此对于要求结果为二进制数据(如图像数据)的不能用此函数返回。

  1. SQLITE_API int sqlite3_get_table(  
  2. sqlite3 *db,          /* An open database */  
  3. const char *zSql,     /* SQL to be evaluated */  
  4. char ***pazResult,    /* Results of the query */  
  5. int *pnRow,           /* Number of result rows written here */  
  6. int *pnColumn,        /* Number of result columns written here */  
  7. char **pzErrmsg       /* Error msg written here */  
  8. ); 

例如我们要查询person中的所有数据:

  1. char **table = NULL;  
  2. int row,col;  
  3. result = sqlite3_get_table(db, “SELECT name,age,birthday from person”, &table, &row, &col, &errmsg);  
  4. NSAssert(result==SQLITE_OK, @”SQL ERROR: %s”, errmsg); 

那么字符串数组table中就包含所有的表信息,本例中每行3个元素(name、age和birthday),table***行元素是字段名字,如table[0]是”name”,table[1]是”age”,table[2]是”birthday”。table的第二行才是实际的数据,如table[3]是”张三”,table[4]是”24″,table[5]是”1981-10-21 12:00:01″。

通过sqlite3_prepare()、sqlite3_step()、sqlite3_bind_xxx()以及sqlite3_finalize()等一系列函数,可以逐行获取数据,并可以获取二进制数据。

sqlite3_prepare()用于编译一个SQL语句,返回一个sqlite3_stmt结构指针。sqlite3_stmt结构指针用于sqlite3_step()、sqlite3_bind_xxx()以及sqlite3_finalize()等函数中。sqlite3_step()用于将当前记录指向下一个。sqlite3_bind_xxx()等一系列函数会获取当前记录中各个字段对应的值。***调用一下sqlite3_finalize()用于释放一些资源。

3、其他高级应用

(1)创建内存数据库

通常SQLite3数据库存储在磁盘文件中,所以对数据库的读写等操作就会精彩的对磁盘文件进行读写。SQLite3也可以将数据库建立在内存中,但是要注意建立内存的数据是易失的(程序退出时内存便会释放)。我们知道磁盘的读写比内存的读写要慢很多很多,有时候我们对读写速度要求很高,但是对数据是否时持久保存并不感兴趣,这时使用内存数据库***不过了。

创建内存数据库很简单,只需要把打开数据库的文件名改为“:memory:”即可。

  1. int result = sqlite3_open(“:memory:”, &db);  
  2. NSAssert(result==SQLITE_OK, @”Can’t open database %@”, dbPath); 

(2)创建自定义SQL语句函数

有时候我们想定义一个函数来判断一个人是否满足结婚条件(男性大于22岁,女性大于20岁),可惜SQL语句中并没有提供如此复杂的判断。这时创建一个自定义函数是非常方便的。

  1. static void db_func_canmarry(sqlite3_context *context, int argc, sqlite3_value **argv){  
  2. int gender = sqlite3_value_int(argv[0]);  
  3. int age = sqlite3_value_int(argv[1]);  
  4. int canmarry = 0;  
  5. if (gender == 0 && age > 22) {  
  6. canmarry = 1;  
  7. }  
  8. else if (gender == 1 && age > 20){  
  9. canmarry = 0;  
  10. }  
  11. sqlite3_result_int(context, canmarry);  

定义好函数,把这个函数加入到数据库SQL语句中。

  1. sqlite3_create_function(db, “CANMARRY”, 2, SQLITE_UTF8, NULL, &db_func_canmarry, NULL, NULL); 

以后我们执行SQL语句SELECT * FROM person WHERE CANMARRY(gender,age) 就可以获取到所有满足结婚条件的人。

(3)分页查询

数据库查询时常常碰到需要分页显示结果的情况,这时候我们使用SQL语句LIMIT关键字就非常方便了。比如返回20行起的10行数据

  1. SELECT * FROM person WHERE CANMARRY(gender,age) LIMIT 20, 10 

小结:IOS开发学习笔记iOS数据库编程的内容介绍完了,希望通过本文的学习能对你有所帮助!关于更多IOS开发的内容,请参考IOS开发频道

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-08-22 16:08:46

IOS开发数据库

2013-04-01 10:49:51

iOS开发sqlite数据库

2011-07-21 17:40:43

iOS 多核 内存

2011-08-16 14:59:31

IOS开发ViewDidUnloiOS 5

2011-08-30 13:33:29

Qt数据库

2013-09-12 12:55:53

iOS开发

2012-05-14 16:59:40

iOS

2013-03-28 09:45:34

iOS学习笔记总结整理

2015-09-01 10:37:54

ios静态库开发

2011-08-03 09:44:18

IOS开发 UITextFiel UITableVie

2011-07-08 18:28:43

iOS 接口

2011-07-21 11:05:18

iOS 族谱 Cocoa

2011-08-11 14:23:57

SQL Server 索引分区

2011-08-25 11:08:21

Sybase数据库

2011-08-09 16:08:58

IOS游戏Cocos2d

2012-05-14 17:06:46

iOS

2011-07-22 16:57:44

iOS 通知

2015-09-11 11:02:23

ios静态库开发

2013-07-25 13:30:35

iOS开发学习读取照片库

2013-07-21 18:18:00

iOS开发ASIHttpRequ
点赞
收藏

51CTO技术栈公众号