相信大家都熟悉OC使用FMDB第三方库,进行数据库操作,增、删、改、查,现在我就来利用代码展示一下Swift对此库的使用方法,我是通过Pods添加的第三方库,如果手动添加记得创建桥接文件,在文件中调用头文件。如果不会的可以看我以前的文章里有介绍Swift调用OC文件代码http://blog.csdn.net/hbblzjy/article/details/52252630

效果图:

如果不知道FMDB的这里再简单的介绍一下:

FMDB是一个和iOS的SQLite数据库操作相关的第三方框架。主要把C语言操作数据库的代码用OC进行了封装。使用者只需调用该框架的API就能用来创建并连接数据库,创建表,查询等。轻量级,灵活。不消耗太多性能,FMDB将C语言的iOS系统的SQLite数据库的操作代码用OC进行封装,面向对象,容易理解和使用,提供了线程不安全的解决方案。重要的类:FMDatabase数据库类、FMResultSet结果集、FMDatabaseQueue线程类等。

首先创建一个表格,添加四个按钮,分别是增加、删除、修改、查询

代码如下:

myTableView = UITableView.init(frame: CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height-50), style: .Plain);
        myTableView.rowHeight = 60;
        myTableView.delegate = self;
        myTableView.dataSource = self;
        self.view.addSubview(myTableView);
        
        let arr:NSArray = ["增加","删除","修改","查询"];
        let widthF:CGFloat = self.view.frame.size.width/4;
        
        for i in 0...arr.count-1 {
            let buttonN = UIButton.init(frame: CGRectMake(widthF*CGFloat(i), self.view.frame.size.height-50, widthF, 50));
            buttonN.setTitle(arr[i] as? String, forState: .Normal);
            buttonN.setTitleColor(UIColor.blueColor(), forState: .Normal);
            buttonN.backgroundColor = UIColor.lightGrayColor();
            buttonN.titleLabel?.adjustsFontSizeToFitWidth = true;
            buttonN.tag = i+100;
            buttonN.addTarget(self, action: #selector(btnClick), forControlEvents: .TouchUpInside);
            self.view.addSubview(buttonN);
        }

然后是创建一个数据库的管理类,这里我们可以创建一个包含线程的类,这样对数据操作时,不易出错

FMDBQueueManager.swift文件中的代码:

func openDB(dbName : String){
        
        let path = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true).last!
        print(path)
        dbQueue = FMDatabaseQueue(path: "\(path)/\(dbName)")
        
        createTable()
    }
    
    func createTable () {
        let sql = "CREATE TABLE IF NOT EXISTS contact_people ('id' integer NOT NULL,'name' text NOT NULL,'phoneNum' text NOT NULL,PRIMARY KEY('id'))"
        dbQueue?.inDatabase({ (db) -> Void in
            try! db.executeUpdate(sql, values: [])
        })
    }

创建一个对数据库操作的Model类,FMDBModel.swift

//注意SQL语句的书写方式
    //增加数据
    func insert(){
        
        let sql = "INSERT INTO contact_people (name, phoneNum) values ('\(self.name!)', '\(self.phoneNum!)')"
        //下面的写法存在线程不安全的问题
        //       try! FMDBManager.ShareManager.db?.executeUpdate(sql, values: [])
        
        ///下面的写法是线程安全的写法
        FMDBQueueManager.shareFMDBQueueManager.dbQueue?.inDatabase({ (db) ->Void in
            
            try! db.executeUpdate(sql, values: [])
        })
    }
    //删除数据
    func delete(){
        let sql = "delete from contact_people"
        FMDBQueueManager.shareFMDBQueueManager.dbQueue?.inDatabase({ (db) -> Void in
            try! db.executeUpdate(sql, values: [])
        })
    }
    //更新数据
    func update(){
        let sql = "update contact_people set name = '\(self.name!)' where phoneNum = '12345678'"
        FMDBQueueManager.shareFMDBQueueManager.dbQueue?.inDatabase({ (db) -> Void in
            try! db.executeUpdate(sql, values: [])
        })
    }
    //查询数据
    class func query() -> [[String : AnyObject]]{
        
        let sql = "SELECT * FROM contact_people"
        var resultArray: [[String : AnyObject]] = []
        
        FMDBQueueManager.shareFMDBQueueManager.dbQueue?.inDatabase({ (db)->Void in
            
            ///执行查询
            if let result = try? db.executeQuery(sql, values: []){
                ///遍历查询后的数据
                while result.next(){
                    ///获取数据
                    let nameStr = result.stringForColumn("name")
                    let phoneNumStr = result.stringForColumn("phoneNum")
                    let dict = ["name": nameStr, "phoneNum": phoneNumStr]
                    resultArray.append(dict)
                }
            }
        })
        ///查找到数据后将数据返回
        return resultArray
    }
}

这些工作结束后,就可以在界面中进行操作,源代码请自行下载,如果有问题请留言,谢谢....

源代码:http://download.csdn.net/detail/hbblzjy/9660218

Swift基础之对FMDB第三方的使用方法的更多相关文章

  1. python基础-7模块,第三方模块安装方法,使用方法。sys.path os sys time datetime hashlib pickle json requests xml

    模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个函数才 ...

  2. swift基础:第六部分:类与对象

    http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...

  3. swift基础:第二部分:函数和闭包

    今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...

  4. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

  5. Swift基础语法学习总结

    Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift ...

  6. swift -- 基础

    swift -- 基础 1.常量和变量 常量: let 变量: var 2.声明常量和变量 常量的声明: let let  a = 1         //末尾可以不加分号,等号两边的空格必须对应(同 ...

  7. Swift基础语法

    简介 特点 (1)优于OC,快速,安全 (2)取消了预编译指令包括宏定义(OC用的太多了) (3)取消了OC指针和不安全访问的使用(看不到星星了) (4)舍弃 Objective-C 早期应用 Sma ...

  8. iOS Swift 模块练习/swift基础学习

    SWIFT项目练习     SWIFT项目练习2 iOS Swift基础知识代码 推荐:Swift学习使用知识代码软件 0.swift中的宏定义(使用方法代替宏) 一.视图  +控件 1.UIImag ...

  9. Swift基础学习

    Swift基础学习  http://c.biancheng.net/cpp/html/2242.html 这个网站最近看了一下,对于基本语法解释概括的相对全面,如同重新练习一遍OC似的,挺全面的,谢谢 ...

随机推荐

  1. [SDOI 2008]Cave 洞穴勘测

    Description 辉辉热衷于洞穴勘测.某天,他按照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘测,辉辉发现这片区域由n个洞穴(分别编号为1到n)以及若干通道组成,并且每条通道连接了恰好 ...

  2. [NOIp 2015]斗地主

    Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3& ...

  3. bzoj 2436: [Noi2011]Noi嘉年华

    Description NOI2011 在吉林大学开始啦!为了迎接来自全国各地最优秀的信息学选手,吉林大学决定举办两场盛大的 NOI 嘉年华活动,分在两个不同的地点举办.每个嘉年华可能包含很多个活动, ...

  4. 【Codeforces Round #430 (Div. 2) A C D三个题】

    ·不论难度,A,C,D自己都有收获! [A. Kirill And The Game] ·全是英文题,述大意:    给出两组区间端点:l,r,x,y和一个k.(都是正整数,保证区间不为空),询问是否 ...

  5. php中sql语句常见错误

    .php文件中sql语句的写法导致的错误如下: 1.$logSql="select * from jd_login where uname=".$u."and upwd= ...

  6. Linux下安装3.0以上的python

    Linux下自带的python2.7是不建议删除的,很多系统软件依赖python2.7,但是现在我们学习python一般需要python3.0,下面介绍安装python3.0. 1.进入python官 ...

  7. Linux学习之CentOS(八)----详解文件的搜寻、查找(转)

    which (寻找『运行档』) [root@www ~]# which [-a] command 选项或参数: -a :将所有由 PATH 目录中可以找到的命令均列出,而不止第一个被找到的命令名称 分 ...

  8. 函数的属性和方法之call、apply 及bind

    一.前言 ECMAScript中的函数是对象,因此函数也有属性和方法.每个函数都包含两个属性:length和prototype.每个函数也包含两个非继承来的方法:apply()和call(),还有一些 ...

  9. iOS开发-文件管理

    iOS学习笔记(十七)--文件操作(NSFileManager) 浅析 RunLoop 解决EXC_BAD_ACCESS错误的一种方法--NSZombieEnabled iOS开发--Swift篇&a ...

  10. python脚本批量生成数据

    在平时的工作中,经常会遇到造数据,特别是性能测试的时候更是需要大量的数据.如果一条条的插入数据库或者一条条的创建数据,效率未免有点低.如何快速的造大量的测试数据呢?在不熟悉存储过程的情况下,今天给大家 ...