博客
关于我
Swift使用FMDB操作SQLite
阅读量:426 次
发布时间:2019-03-06

本文共 3385 字,大约阅读时间需要 11 分钟。

  SQLite大家都懂的。本地数据库,在移动设备上使用广泛。IOS平台上自然也少不了它。最近自己折腾一个小App的时候需要使用sqlite本地数据库,上Github搜了下IOS下对SQLite的三方封装有个星星很多的FMDB。不过是Obiect-C的库,我是使用Swift的,本以为不能用了,不过后折腾了下发现在Swift下使用oc的库非常简单。下面我就介绍下如何在Swift下使用oc的FMDB库。

  1.下载

  第一步自然是去下载FMDB了。https://github.com/ccgus/fmdb

  2.建立桥接

  把下载下来的zip解压。打开项目文件夹,找到fmdb文件夹,把里面所有的文件选中,拖动到你的Swfit项目中。

 

  

  这时候XCode会自动提示你是否要建立桥接,选YES。XCode就会自动建立好oc到Swift的桥接了。

  

  接下来我们在Swift项目下找到一个叫做BabyLog-Bridging-Header的文件,打开编辑。在里面输入:#import "FMDB.h"

  

  这样我们FMDB到Swift的桥接头就建好了。

  3.使用

  有了桥接头,我们就可以欢快的使用FMDB了。下面给出CURD的简单实例,不多说看代码吧。

  获取数据库

  如果数据库不存在则建立数据库表,存在则返回数据库对象。  

////  Db.swift//  BabyLog////  Created by mj.zhou on 15/3/4.//  Copyright (c) 2015年 mjstudio. All rights reserved.//import Foundationvar logs = [FeedLog]()class Db{        class func getDb()->FMDatabase{            let filemgr = NSFileManager.defaultManager()        let dirPaths =        NSSearchPathForDirectoriesInDomains(.DocumentDirectory,            .UserDomainMask, true)                let docsDir = dirPaths[0] as String                var databasePath = docsDir.stringByAppendingPathComponent("feedlog.db")                if !filemgr.fileExistsAtPath(databasePath) {                        let db = FMDatabase(path: databasePath)                        if db == nil {                println("Error: \(db.lastErrorMessage())")            }                        if db.open() {                let sql_stmt = "CREATE TABLE IF NOT EXISTS FEEDLOGS (ID TEXT PRIMARY KEY, COUNT INTEGER, TYPE INTEGER,LOGTIME DATETIME,LOGDAY TEXT, REMARK TEXT)"                if !db.executeStatements(sql_stmt) {                    println("Error: \(db.lastErrorMessage())")                }                db.close()            } else {                println("Error: \(db.lastErrorMessage())")            }        }                let feedlogDb = FMDatabase(path: databasePath)        return feedlogDb    }    }

  插入数据

class func insert(log:FeedLog){                let sql="INSERT INTO FEEDLOGS (ID,COUNT,TYPE,LOGTIME,LOGDAY,REMARK) "+"VALUES (?,?,?,?,?,?)"        let db = Db.getDb()        db.open()        db.executeUpdate(sql, withArgumentsInArray: [log.id,log.count,log.type,log.logTime,log.logDay,log.remark])        db.close()    }

  更新数据

class func update(log:FeedLog){                let sql = "UPDATE FEEDLOGS SET COUNT=?,TYPE=?,LOGTIME=?,LOGDAY=?,REMARK=? WHERE ID=?"        let db = Db.getDb()        db.open()        db.executeUpdate(sql, withArgumentsInArray: [log.count,log.type,log.logTime,log.logDay,log.remark,log.id])        db.close()    }

  删除数据

class func remove(id:String){        let sql = "DELETE FROM FEEDLOGS WHERE ID = ?"        let db = Db.getDb()        db.open()        db.executeUpdate(sql, withArgumentsInArray: [id])        db.close()    }

    查询数据

class func select(id:String)->FeedLog?{                let sql = "SELECT * FROM FEEDLOGS WHERE ID = ?"        let db = Db.getDb()        db.open()        let rs = db.executeQuery(sql, withArgumentsInArray: [id])        var log:FeedLog?=FeedLog()        while rs.next() {            log?.id=rs.stringForColumn("ID")            log?.count=Int(rs.intForColumn("COUNT"))            log?.type=Int(rs.intForColumn("TYPE"))            log?.remark=rs.stringForColumn("REMARK")            log?.logTime=rs.dateForColumn("LOGTIME")            log?.logDay=rs.stringForColumn("LOGDAY")        }        db.close()                return log    }

 

转载地址:http://ildyz.baihongyu.com/

你可能感兴趣的文章
我们真的需要JWT吗?
查看>>
Swift使用FMDB操作SQLite
查看>>
使用MySQL Shell创建MGR
查看>>
win10新版wsl2使用指南
查看>>
spring-boot 使用hibernate validation对参数进行优雅的校验
查看>>
关于我
查看>>
数据结构实验之栈四:后缀式求值
查看>>
图结构练习——最小生成树(prim算法(普里姆))
查看>>
sdut 2498【aoe 网上的关键路径】
查看>>
【PHP自定义显示系统级别的致命错误和用户级别的错误】
查看>>
【PHP对XML文件的操作技术【完整版】】
查看>>
【Java环境变量的配置问题】
查看>>
【JAVA多线程中使用的方法】
查看>>
【JAVA网络流之URL】
查看>>
【Java远程debug】
查看>>
asp.net 5 中应用程序根目录及物理文件根目录的获取方式 此文已过期,不再适应rc1以后的版本
查看>>
最通俗易懂的囚徒困境
查看>>
递推的思维构建与技巧实现
查看>>
五道逻辑思维题
查看>>
第八届蓝桥杯程序设计大赛 国赛 填空题第一题 平方十位数
查看>>