IOS sqlite數據庫操做。步驟是:sql
先加入sqlite開發庫libsqlite3.dylib,數據庫
新建或打開數據庫,瀏覽器
建立數據表,函數
插入數據,工具
查詢數據並打印學習
一、新建項目sqliteDemo,添加使用sqlite的庫libsqlite3.dylib
![](http://static.javashuo.com/static/loading.gif)
二、sqlite 的方法
sqlite3 *db, 數據庫句柄,跟文件句柄FILE很相似spa
sqlite3_stmt *stmt, 這個至關於ODBC的Command對象,用於保存編譯好的SQL語句
sqlite3_open(), 打開數據庫,沒有數據庫時建立。
sqlite3_exec(), 執行非查詢的sql語句
Sqlite3_step(), 在調用sqlite3_prepare後,使用這個函數在記錄集中移動。
Sqlite3_close(), 關閉數據庫文件
還有一系列的函數,用於從記錄集字段中獲取數據,如
sqlite3_column_text(), 取text類型的數據。
sqlite3_column_blob(),取blob類型的數據
sqlite3_column_int(), 取int類型的數據.net
三、獲取沙盒目錄,並建立或打開數據庫。
viewController.h頭文件添加一個成員變量,幷包含頭文件sqlite3.h插件
- #import <UIKit/UIKit.h>
- #import <sqlite3.h>
-
-
- @interface ViewController : UIViewController
- {
- sqlite3 *db;
- }
- @end
在.m文件 定義宏,方面後面使用orm
- #define DBNAME @"personinfo.sqlite"
- #define NAME @"name"
- #define AGE @"age"
- #define ADDRESS @"address"
- #define TABLENAME @"PERSONINFO"
- NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *documents = [paths objectAtIndex:0];
- NSString *database_path = [documents stringByAppendingPathComponent:DBNAME];
-
- if (sqlite3_open([database_path UTF8String], &db) != SQLITE_OK) {
- sqlite3_close(db);
- NSLog(@"數據庫打開失敗");
- }
sqlite3_open,若是數據不存在,則建立。運行。這是在沙盒目錄下能看到數據庫文件(如何打開模擬器沙盒目錄請參考:IOS學習之IOS沙盒(sandbox)機制和文件操做(一))
![](http://static.javashuo.com/static/loading.gif)
四、建立數據表
建立一個獨立的執行sql語句的方法,傳入sql語句,就執行sql語句
- -(void)execSql:(NSString *)sql
- {
- char *err;
- if (sqlite3_exec(db, [sql UTF8String], NULL, NULL, &err) != SQLITE_OK) {
- sqlite3_close(db);
- NSLog(@"數據庫操做數據失敗!");
- }
- }
建立數據表PERSONINFO的語句
- NSString *sqlCreateTable = @"CREATE TABLE IF NOT EXISTS PERSONINFO (ID INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, address TEXT)";
- [self execSql:sqlCreateTable];
運行程序,數據表建立了。怎麼知道數據表建立了呢?咱們用火狐的Sqlite Manager插件工具打開數據庫文件看看。能夠在火狐瀏覽器裏安裝這個插件。打開
![](http://static.javashuo.com/static/loading.gif)
四個字段都出現是表中了。
五、插入數據:
- NSString *sql1 = [NSString stringWithFormat:
- @"INSERT INTO '%@' ('%@', '%@', '%@') VALUES ('%@', '%@', '%@')",
- TABLENAME, NAME, AGE, ADDRESS, @"張三", @"23", @"西城區"];
-
- NSString *sql2 = [NSString stringWithFormat:
- @"INSERT INTO '%@' ('%@', '%@', '%@') VALUES ('%@', '%@', '%@')",
- TABLENAME, NAME, AGE, ADDRESS, @"老六", @"20", @"東城區"];
- [self execSql:sql1];
- [self execSql:sql2];
運行程序,插入兩條數據,用火狐的sqlite工具查看
![](http://static.javashuo.com/static/loading.gif)
六、查詢數據庫並打印數據
- NSString *sqlQuery = @"SELECT * FROM PERSONINFO";
- sqlite3_stmt * statement;
-
- if (sqlite3_prepare_v2(db, [sqlQuery UTF8String], -1, &statement, nil) == SQLITE_OK) {
- while (sqlite3_step(statement) == SQLITE_ROW) {
- char *name = (char*)sqlite3_column_text(statement, 1);
- NSString *nsNameStr = [[NSString alloc]initWithUTF8String:name];
-
- int age = sqlite3_column_int(statement, 2);
-
- char *address = (char*)sqlite3_column_text(statement, 3);
- NSString *nsAddressStr = [[NSString alloc]initWithUTF8String:address];
-
- NSLog(@"name:%@ age:%d address:%@",nsNameStr,age, nsAddressStr);
- }
- }
- sqlite3_close(db);
打印結果:
- 2012-06-29 13:25:32.205 sqlitDemo[3587:f803] name:張三 age:23 address:西城區
- 2012-06-29 13:25:32.206 sqlitDemo[3587:f803] name:老六 age:20 address:東城區
最後關閉數據庫。
例子代碼:http://download.csdn.net/detail/totogo2010/4400911