Swift開發(fā)對FMDB的二次封裝

iOS開發(fā)對于本地持久化數(shù)據(jù)提供了多種解決途徑(歸檔,寫入文件,寫入plist,存入本地數(shù)據(jù)庫等等),今天我們就來看看sqlite的封裝和使用馆匿。有的小伙伴用coreData來操作sqlite竭钝,有的直接使用sql語句來操作sqlite梨撞,但大部分開發(fā)者都是FMDB的忠實粉絲。FMDB優(yōu)秀的封裝邏輯是開發(fā)者鐘情的原因所在香罐,但是在優(yōu)秀的第三方都會出現(xiàn)被棄用的可能性卧波,一旦此種情況發(fā)生而我們代碼到處充斥著此第三方的代碼,那么代碼的維護將是毀滅性的穴吹,而將此第三方封裝成一個獨立的工具類可完美的解決此問題幽勒!

上代碼!8哿睢啥容!

import FMDB
class DB: NSObject {
    //單例
    static let shareServeTool = DB()

    //定義管理數(shù)據(jù)庫的對象
    var db:FMDatabase!

    //線程鎖,通過加鎖和解鎖來保證所做操作數(shù)據(jù)的安全性
    let lock = NSLock()

    /**
     *1.重寫父類的構(gòu)造方法
     */

    override init() {
        super.init()
        //設(shè)置數(shù)據(jù)庫的路徑;fmdb.sqlite是由自己隨意命名
        let path = NSTemporaryDirectory().appending("library.db")
        print(path)

        //構(gòu)造管理數(shù)據(jù)庫的對象
        db = FMDatabase(path: path)

        //判斷數(shù)據(jù)庫是否打開成功;如果打開失敗則需要創(chuàng)建數(shù)據(jù)庫
        if !db.open() {
            print("數(shù)據(jù)庫打開失敗")
            return
        }else{
            self.create()
        }
    }

    /*****************************1.創(chuàng)建表********************************/
    func create()  {
        //創(chuàng)建數(shù)據(jù)庫
        //student表達表名,由自己命名
        //uid,data是需要收藏的模型中的字段顷霹,須根模型中保持一致
        //varchar表示字符串咪惠,integer表示數(shù)字让网,blob表示二進制數(shù)據(jù)NSData
        let createSql = "CREATE TABLE IF NOT EXISTS userCache(keys varchar(300),valu varchar(300))"

        //執(zhí)行sel語句進行數(shù)據(jù)庫的創(chuàng)建
        do {
            try db.executeUpdate(createSql, values: nil)
        }catch {
            print(db.lastErrorMessage())
        }
    }

    /*****************************2.增********************************/

    func insertDataWith(valu:String,keys:String) {

        //加鎖操作
        lock.lock()

        //sel語句
        //(?,?)表示需要傳的值刊愚,對應(yīng)前面出現(xiàn)幾個字段,后面就有幾個問號
        let insetSql = "insert into user(keys , valu) values(?,?)"

        //更新數(shù)據(jù)庫
        do {
            try db.executeUpdate(insetSql, values: [keys,valu])
        }catch {
            print(db.lastErrorMessage())
        }

        //解鎖
        lock.unlock()

    }

    /*****************************3.刪********************************/

    func deleteDataWith(keys:String) {
        //加鎖操作
        lock.lock()
        //sel語句
        //where表示需要刪除的對象的索引褥琐,是對應(yīng)的條件
        let deleteSql = "delete from user where keys = ?"
        //更新數(shù)據(jù)庫
        do{
            try db.executeUpdate(deleteSql, values: [keys])
        }catch {
            print(db.lastErrorMessage())
        }
        //解鎖
        lock.unlock()
    }

    /*****************************4.改********************************/

    func updateDataWith(valu:String,keys:String) {
        //加鎖
        lock.lock()
        //where id = ?中的id可傳可不傳
        let updateSql = "update user set values = ? where keys = ?"
        //更新數(shù)據(jù)庫
        do{
            try db.executeUpdate(updateSql, values: [valu])
        }catch {
            print(db.lastErrorMessage())
        }
        //解鎖
        lock.unlock()
    }

    /********5.判斷數(shù)據(jù)庫中是否有當(dāng)前數(shù)據(jù)(查找一條數(shù)據(jù))*********************/

    func isHasDataInTable(keys:String) -> Bool {
        let isHas = "select * from user where keys = ?"
        do{
            let set = try db.executeQuery(isHas, values: [keys])
            //查找當(dāng)前行朵纷,如果數(shù)據(jù)存在炭臭,則接著查找下一行
            if set.next() {
                return true
            }else {
                return false
            }
        }catch {}
        return true
    }

    /********6.根據(jù)條件查找數(shù)據(jù)*********************/
    func fetchAllData(keys:String) ->([String]){
        let fetchSql = "select * from user where keys = ?"
        //用于符合條件數(shù)據(jù)的臨時數(shù)組
        var tempArray = [String]()
        do {
            let set = try db.executeQuery(fetchSql, values: [keys])
            //循環(huán)遍歷結(jié)果
            while set.next() {
                var valu = String()
                //給字段賦值
                valu = set.string(forColumn: "valu")!
                tempArray.append(valu)
            }

        }catch {
            print(db.lastErrorMessage())
        }
        return (tempArray)
    }

    func fetchAllData() ->([String],[String] ){
        let fetchSql = "select * from user"
        //用于承接所有數(shù)據(jù)的臨時數(shù)組
        var tempArray = [String]()
        var tempArrays = [String]()
        do {
            let set = try db.executeQuery(fetchSql, values: nil)
            //循環(huán)遍歷結(jié)果
            while set.next() {
                var values = String()
                var keys = String()
                //給字段賦值
                values = set.string(forColumn: "data")!
                keys = set.string(forColumn: "keys")!
                tempArray.append(values)
                tempArrays.append(keys)
            }
        }catch {
            print(db.lastErrorMessage())
        }
        return (tempArray,tempArrays)
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市袍辞,隨后出現(xiàn)的幾起案子鞋仍,更是在濱河造成了極大的恐慌,老刑警劉巖搅吁,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件威创,死亡現(xiàn)場離奇詭異,居然都是意外死亡谎懦,警方通過查閱死者的電腦和手機肚豺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來界拦,“玉大人吸申,你說我怎么就攤上這事∠淼椋” “怎么了截碴?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長枪萄。 經(jīng)常有香客問我隐岛,道長,這世上最難降的妖魔是什么瓷翻? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任聚凹,我火速辦了婚禮,結(jié)果婚禮上齐帚,老公的妹妹穿的比我還像新娘妒牙。我一直安慰自己,他們只是感情好对妄,可當(dāng)我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布湘今。 她就那樣靜靜地躺著,像睡著了一般剪菱。 火紅的嫁衣襯著肌膚如雪摩瞎。 梳的紋絲不亂的頭發(fā)上拴签,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機與錄音旗们,去河邊找鬼蚓哩。 笑死,一個胖子當(dāng)著我的面吹牛上渴,可吹牛的內(nèi)容都是我干的岸梨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼稠氮,長吁一口氣:“原來是場噩夢啊……” “哼曹阔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起隔披,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤赃份,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后锹锰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芥炭,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年恃慧,在試婚紗的時候發(fā)現(xiàn)自己被綠了园蝠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡痢士,死狀恐怖彪薛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情怠蹂,我是刑警寧澤善延,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站城侧,受9級特大地震影響易遣,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜嫌佑,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一豆茫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧屋摇,春花似錦揩魂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春倦挂,著一層夾襖步出監(jiān)牢的瞬間畸颅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工妒峦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留重斑,地道東北人兵睛。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓肯骇,卻偏偏與公主長得像,于是被迫代替她去往敵國和親祖很。 傳聞我的和親對象是個殘疾皇子笛丙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容