IOS開發學習筆記iOS數據庫編程是本文要介紹的內容,主要是來了解IOS開發中的數據庫的學習,具體內容來看詳解。在IOS開發過程中常常會用到數據庫,而SQLite3是中支持的數據庫。下面簡單介紹一下iPhone中SQLite3數據庫的用法:
SQLite3是一個輕量級的數據庫,完全使用C語言編寫,使用簡單方便。它是一個嵌入到程序進程的數據庫,和其他一些數據庫(MySQL,MS SQL)不同,它沒有獨立的進程。
1、打開數據庫
首先聲明一個數據庫變量
[pre]
-
sqlite3 *
db
-
=
NULL
-
;
[/pre]每一個SQLite3都是一個文件,打開一個數據庫只需要調用一次sqlite3_open函數:
[pre]
-
SQLITE_API int sqlite3_open(
- const char *filename, /* Database filename (UTF-8) */ sqlite3 **ppDb /* OUT: SQLite db handle */
- );
[/pre]filename是數據庫的路徑,ppDb是指向返回的sqlite3數據庫,返回SQLITE3_OK則表示正常。比如我們打開Document目錄下的“Test.db”數據庫:
[pre]
-
int
result
-
=
sqlite3_open
-
([dbPath UTF8String], &db);
- NSAssert(result==SQLITE_OK, @”Can’t open database %@”, dbPath);
[/pre]注意:如果dbPath路徑下的數據庫不存在,那么打開這個數據庫將會創建一個空的數據庫。
2、執行SQL語句
SQLite3有3種執行SQL語句的方法:
通過sqlite3_exec()函數,適用於執行(非查詢)語句:如CREATE TABLE、INSERT,REPLACE,DELETE等。
[pre]
-
SQLITE_API int sqlite3_exec(
- sqlite3*, /* An open database */ const char *sql, /* SQL to be evaluated */
- int (*callback)(void*,int,char**,char**), /* Callback function */ void *, /* 1st argument to callback */
- char **errmsg /* Error msg written here */ );
[/pre]比如我們要創建一個表示個人(person)的表,就可以使用sqlite3_exec()函數。person表中包括名字(name)、性別(gender)、年齡(age)和生日(birthday)這幾個字段。代碼如下:
[pre]
-
char *
errmsg
-
=
NULL
- result = sqlite3_exec(db, “CREATE TABLE person (” “name
-
;
TEXT
- “gender INTEGER,” “age INTEGER,”
- “birthday DATE)”, NULL, NULL, &errmsg); NSAssert(
-
,”
result
-
==SQLITE_OK, @”Can’t CREATE TABLE: %s”, errmsg);
[/pre]通過sqlite3_get_table()函數,適用於查詢語句SELECT。由於此函數返回一個字符串數組,因此對於要求結果為二進制數據(如圖像數據)的不能用此函數返回。
[pre]
-
SQLITE_API int sqlite3_get_table(
- sqlite3 *db, /* An open database */ const char *zSql, /* SQL to be evaluated */
- char ***pazResult, /* Results of the query */ int *pnRow, /* Number of result rows written here */
- int *pnColumn, /* Number of result columns written here */ char **pzErrmsg /* Error msg written here */
- );
[/pre]例如我們要查詢person中的所有數據:
[pre]
-
char **
table
-
=
NULL
- int row,col;
-
;
result
-
=
sqlite3_get_table
-
(db, “SELECT name,age,birthday from person”, &table, &row, &col, &errmsg);
- NSAssert(result==SQLITE_OK, @”SQL ERROR: %s”, errmsg);
[/pre]那么字符串數組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:”即可。
[pre]
-
int
result
-
=
sqlite3_open
-
(“:memory:”, &db);
- NSAssert(result==SQLITE_OK, @”Can’t open database %@”, dbPath);
[/pre](2)創建自定義SQL語句函數
有時候我們想定義一個函數來判斷一個人是否滿足結婚條件(男性大於22歲,女性大於20歲),可惜SQL語句中並沒有提供如此復雜的判斷。這時創建一個自定義函數是非常方便的。
[pre]
- int gender = sqlite3_value_int(argv[0]); int
-
static void db_func_canmarry(sqlite3_context *context, int argc, sqlite3_value **argv){
age
-
=
sqlite3_value_int
- int canmarry = 0; if (
-
(argv[1]);
gender
-
== 0 && age
>
- canmarry = 1; }
- else if (gender == 1 && age > 20){
-
22) {
canmarry
-
=
0
-
;
- } sqlite3_result_int(context, canmarry);
- }
[/pre]定義好函數,把這個函數加入到數據庫SQL語句中。
[pre]
-
sqlite3_create_function(db, “CANMARRY”, 2, SQLITE_UTF8, NULL, &db_func_canmarry, NULL, NULL);
[/pre]以后我們執行SQL語句SELECT * FROM person WHERE CANMARRY(gender,age) 就可以獲取到所有滿足結婚條件的人。
(3)分頁查詢
數據庫查詢時常常碰到需要分頁顯示結果的情況,這時候我們使用SQL語句LIMIT關鍵字就非常方便了。比如返回20行起的10行數據
[pre]
-
SELECT * FROM person WHERE CANMARRY(gender,age) LIMIT 20, 10