iOS基礎7:資料庫

來源:互聯網
上載者:User

iOS基礎7:資料庫

在當今智能手機的天下,我們很多資料都是儲存在手機上,如備忘錄,通訊錄等,鑌哥,告訴你,在各種檔案格式在搜尋與儲存的速度都比不上資料庫快,畢竟資料庫在儲存的時候經過特殊格式安排的。而不論是ios或者是android,其內部都是採用SQLite這個嵌入式資料庫作為解決方案。因為比起其他商務資料庫,它可就明顯小得多。

SQLite屬於輕量層級的資料庫,它不需要任何設定,更不需要架設任何伺服器。這樣使得它特別適合用於記憶體寸土寸金的嵌入式裝置中。

sqlite的建立資料庫,表,插入查看資料

iOS sqlite資料庫操作。步驟是:

先加入sqlite開發庫libsqlite3.dylib,

建立或開啟資料庫,

建立資料表,

插入資料,

查詢資料並列印

1、建立項目sqliteDemo,添加使用sqlite的庫libsqlite3.dylib


2、sqlite 的方法

sqlite3 *db, 資料庫控制代碼,跟檔案控制代碼FILE很類似

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類型的資料


3、擷取沙箱目錄,並建立或開啟資料庫。

viewController.h標頭檔添加一個成員變數,並包含標頭檔sqlite3.h

[cpp] view plaincopy
  1. #import
  2. #import
  3. @interface ViewController : UIViewController
  4. {
  5. sqlite3 *db;
  6. }
  7. @end

    在.m檔案 定義宏,方面後面使用


    1. #define DBNAME @"personinfo.sqlite"
    2. #define NAME @"name"
    3. #define AGE @"age"
    4. #define ADDRESS @"address"
    5. #define TABLENAME @"PERSONINFO"


      1. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
      2. NSString *documents = [paths objectAtIndex:0];
      3. NSString *database_path = [documents stringByAppendingPathComponent:DBNAME];
      4. if (sqlite3_open([database_path UTF8String], &db) != SQLITE_OK) {
      5. sqlite3_close(db);
      6. NSLog(@"資料庫開啟失敗");
      7. }

        sqlite3_open,如果資料不存在,則建立。運行。這是在沙箱目錄下能看到資料庫檔案(如何開啟模擬器沙箱目錄請參考:iOS學習之iOS沙箱(sandbox)機制和檔案操作(一))



        4、建立資料表

        建立一個獨立的執行sql語句的方法,傳入sql語句,就執行sql語句


        1. -(void)execSql:(NSString *)sql
        2. {
        3. char *err;
        4. if (sqlite3_exec(db, [sql UTF8String], NULL, NULL, &err) != SQLITE_OK) {
        5. sqlite3_close(db);
        6. NSLog(@"資料庫操作資料失敗!");
        7. }
        8. } 建立資料表PERSONINFO的語句


          1. NSString *sqlCreateTable = @"CREATE TABLE IF NOT EXISTS PERSONINFO (ID INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, address TEXT)";
          2. [self execSql:sqlCreateTable]; 運行程式,資料表建立了。怎麼知道資料表建立了呢?我們用Firefox的Sqlite Manager外掛程式工具開啟資料庫檔案看看。可以在Firefox瀏覽器裡安裝這個外掛程式。開啟


            四個欄位都出現是表中了。

            5、插入資料:

            <喎?http://www.bkjia.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KCgoKPGJyPgoKCgoKPG9sIHN0YXJ0PQ=="1" class="dp-cpp">

          3. NSString *sql1 = [NSString stringWithFormat:
          4. @"INSERT INTO '%@' ('%@', '%@', '%@') VALUES ('%@', '%@', '%@')",
          5. TABLENAME, NAME, AGE, ADDRESS, @"張三", @"23", @"西城區"];
          6. NSString *sql2 = [NSString stringWithFormat:
          7. @"INSERT INTO '%@' ('%@', '%@', '%@') VALUES ('%@', '%@', '%@')",
          8. TABLENAME, NAME, AGE, ADDRESS, @"老六", @"20", @"東城區"];
          9. [self execSql:sql1];
          10. [self execSql:sql2]; 運行程式,插入兩條資料,用Firefox的sqlite工具查看


            6、查詢資料庫並列印資料


            1. NSString *sqlQuery = @"SELECT * FROM PERSONINFO";
            2. sqlite3_stmt * statement;
            3. if (sqlite3_prepare_v2(db, [sqlQuery UTF8String], -1, &statement, nil) == SQLITE_OK) {
            4. while (sqlite3_step(statement) == SQLITE_ROW) {
            5. char *name = (char*)sqlite3_column_text(statement, 1);
            6. NSString *nsNameStr = [[NSString alloc]initWithUTF8String:name];
            7. int age = sqlite3_column_int(statement, 2);
            8. char *address = (char*)sqlite3_column_text(statement, 3);
            9. NSString *nsAddressStr = [[NSString alloc]initWithUTF8String:address];
            10. NSLog(@"name:%@ age:%d address:%@",nsNameStr,age, nsAddressStr);
            11. }
            12. }
            13. sqlite3_close(db); 列印結果:

              [cpp] view plaincopy
              1. 2012-06-29 13:25:32.205 sqlitDemo[3587:f803] name:張三 age:23 address:西城區
              2. 2012-06-29 13:25:32.206 sqlitDemo[3587:f803] name:老六 age:20 addre

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.