iOS中sqlite數(shù)據(jù)庫的原生用法
在iOS中,也同樣支持sqlite。目前有很多第三方庫,封裝了sqlite操作,比如swift語言寫的SQLite.swift、蘋果官網(wǎng)也為我們封裝了一個(gè)框架:CoreData。
它們都離不開Sqlite數(shù)據(jù)庫的支持。
本文主要介紹下,如何在swift中使用原生的sqlite的API。
在Xcode中引入sqlite API
新建一個(gè)swift項(xiàng)目后,我們需要讓項(xiàng)目引入sqlite的動(dòng)態(tài)鏈接庫:
1、項(xiàng)目配置界面,選擇Build Phases
2、點(diǎn)開Link Binary With Libraries,點(diǎn)擊+號(hào),在彈窗中輸入sqlite3
完成后:
3、創(chuàng)建橋接文件,在項(xiàng)目目錄下新建一個(gè)頭文件(h):
4、然后使用import導(dǎo)入sqlite庫:
#import "sqlite3.h"
5、最后一步,在項(xiàng)目配置界面,選擇Build Setting,搜索框中輸入swift,在結(jié)果中選擇Objective-C Bridging Header,輸入剛才新建的橋接文件的名稱:
整個(gè)引入工作已經(jīng)完成了,可以測試下是否引入成功,在swift文件中,輸入sqlite3,看是否有sqlite3相關(guān)的智能提示出來。
創(chuàng)建(打開)與關(guān)閉數(shù)據(jù)庫
要?jiǎng)?chuàng)建或者打開一個(gè)sqlite數(shù)據(jù)庫,使用sqlite3_open方法,我們無需手動(dòng)創(chuàng)建一個(gè)數(shù)據(jù)庫文件,如果沒有文件,sqlite3_open方法會(huì)為我們自動(dòng)創(chuàng)建數(shù)據(jù)庫文件,然后打開數(shù)據(jù)庫。
//數(shù)據(jù)庫存放路徑 let sqlitepath = NSHomeDirectory().stringByAppendingPathComponent("Documents/sqlite3.db") //打開數(shù)據(jù)庫,指定數(shù)據(jù)庫文件路徑,如果文件不存在后先創(chuàng)建文件,再打開,所以無需手動(dòng)創(chuàng)建文件 let state = sqlite3_open(sqlitepath, &db) if state == SQLITE_OK{ println("打開數(shù)據(jù)庫成功") }else{ println("打開數(shù)據(jù)庫失敗") }
這里sqlite3_open方法的第二個(gè)參數(shù)是一個(gè)指針,是數(shù)據(jù)庫打開后返回的一個(gè)操作指針,通過使用它,我們可以對數(shù)據(jù)庫進(jìn)行一系列的操作。我們先把它定義在外面,方便我們使用。
var db:COpaquePointer = nil override func viewDidLoad() { super.viewDidLoad() ... }
創(chuàng)建表和刪除表
使用sqlite3_exec方法可以執(zhí)行一段sql語句,主要就是sql語句的差異,其他都一樣:
//創(chuàng)建表 let createtable = "create table if not exists students (id integer primary key autoincrement,name text,stuId integer)" let result = sqlite3_exec(db, createtable, nil, nil, nil) if result == SQLITE_OK{ println("創(chuàng)建表成功") } //刪除表 let removetable = "drop table studets" let result2 = sqlite3_exec(db, removetable, nil, nil, nil) if result2 == SQLITE_OK{ println("刪除表成功") }
插入更新刪除數(shù)據(jù)
插入數(shù)據(jù)使用了占位符,sql語句中使用問號(hào)代表值。使用sqlite3_bind_xxx來綁定值。
//插入數(shù)據(jù) let inserttable = "insert into studets (stuId,name) values(?,?)" var statement:COpaquePointer = nil let result3 = sqlite3_prepare_v2(db, inserttable, -1, &statement, nil) if result3 == SQLITE_OK{ //綁定數(shù)據(jù) sqlite3_bind_int(statement, 1, 1) sqlite3_bind_text(statement, 2, "lijialong", -1, nil) //執(zhí)行 if sqlite3_step(statement) == SQLITE_DONE{ println("數(shù)據(jù)插入成功") } sqlite3_finalize(statement) }
更新數(shù)據(jù)也類似幾個(gè)步驟:
let updatetable = "update studets set name ='ss' where id = 1" var statement:COpaquePointer = nil sqlite3_prepare_v2(db, updatetable, -1, &statement, nil) sqlite3_step(statement) sqlite3_finalize(statement)
刪除數(shù)據(jù):
let deleterow = "delete from studets where name='lijialong'" sqlite3_prepare_v2(db, deleterow, -1, &statement, nil) sqlite3_step(statement) sqlite3_finalize(statement)
查詢數(shù)據(jù)
//查詢數(shù)據(jù) let query = "select * from studets" //這條執(zhí)行后,數(shù)據(jù)就已經(jīng)在sattement中了 sqlite3_prepare_v2(db, query, -1, &statement, nil) //游標(biāo)往下走一步,如果返回SQLITE_ROW就進(jìn)入 while sqlite3_step(statement) == SQLITE_ROW{ let id = sqlite3_column_int(statement, 0) let stuId = sqlite3_column_int(statement, 2) }
以上就是關(guān)于iOS中sqlite數(shù)據(jù)庫的原生用法詳細(xì)介紹,希望對大家的學(xué)習(xí)有所幫助。
- iOS開發(fā)中使用SQL語句操作數(shù)據(jù)庫的基本用法指南
- iOS中FMDB數(shù)據(jù)庫之增刪改查使用實(shí)例
- iOS sqlite對數(shù)據(jù)庫的各種操作(日常整理全)
- iOS App項(xiàng)目中引入SQLite數(shù)據(jù)庫的教程
- iOS開發(fā)中使用FMDB來使程序連接SQLite數(shù)據(jù)庫
- iOS學(xué)習(xí)筆記(十六)——詳解數(shù)據(jù)庫操作(使用FMDB)
- 詳解ios中的SQL數(shù)據(jù)庫文件加密 (使用sqlcipher)
- iOS App使用SQLite之句柄的定義及數(shù)據(jù)庫的基本操作
- IOS 數(shù)據(jù)庫升級數(shù)據(jù)遷移的實(shí)例詳解
- iOS開發(fā)中如何優(yōu)雅的調(diào)試數(shù)據(jù)庫詳解
相關(guān)文章
iOS UILabel根據(jù)內(nèi)容自動(dòng)調(diào)整高度
這篇文章主要為大家詳細(xì)介紹了iOS UILabel根據(jù)內(nèi)容自動(dòng)調(diào)整高度,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06iOS自動(dòng)進(jìn)行View標(biāo)記的方法詳解
這篇文章主要給大家介紹了關(guān)于iOS自動(dòng)進(jìn)行View標(biāo)記的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04IOS 打包出現(xiàn)Missing Push Notification Entitlement 問題解決方案
這篇文章主要介紹了IOS 打包出現(xiàn)Missing Push Notification Entitlement 問題解決方案的相關(guān)資料,需要的朋友可以參考下2016-12-12Objective-C實(shí)現(xiàn)自定義的半透明導(dǎo)航
這篇文章主要為大家詳細(xì)介紹了Objective-C實(shí)現(xiàn)自定義的半透明導(dǎo)航的相關(guān)資料,需要的朋友可以參考下2016-05-05IOS 遠(yuǎn)程通知兼容(IOS7,IOS8)實(shí)例詳解
這篇文章主要介紹了IOS 遠(yuǎn)程通知兼容(IOS7,IOS8)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03iOS在Block中修改外部變量值的實(shí)現(xiàn)代碼
這篇文章主要介紹了iOS在Block中修改外部變量值的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-08-08