swift数据库封装

class HMSQLiteTools: NSObject {
//使用单例对象
static let shared: HMSQLiteTools = HMSQLiteTools()

//创建数据库文件 并l且打开数据库连接
//单例对象一旦创建的时候就打开数据
//必须有值
let queue: FMDatabaseQueue

override init() {
    
    //数据库文件存储在沙盒路径中
    let path = (NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).last! as NSString).appendingPathComponent("weibo.db")
    //如果数据库不存在就创建数据库并且打开连接,如果存在就直接打开连接
    queue = FMDatabaseQueue(path: path)
    
    print(path)
    super.init()
    
    //初始化的时候就创建对应的数据表
    createTable()
    
}


private func createTable() {
    let sql = "CREATE TABLE IF NOT EXISTS T_Status (statusId INTEGER PRIMARY KEY NOT NULL, status TEXT, userId TEXT, create_date TEXT DEFAULT (datetime('now','localtime')));"
    //使用queue中数据库操作的核心对象来执行sql语句
    queue.inTransaction { (db, rollback) in
        //rollback 如果操作失败就执行回滚的操作
        let res = db!.executeStatements(sql)
        if res {
            print("建表成功")
        } else {
            print("失败")
            //执行回滚
            rollback?.pointee = true
        }
    }
}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,948评论 18 139
  • 1、随机数 不需要随机数种子 arc4random()%N + begin:产生begin~begin+N的随机数...
    我是小胡胡123阅读 4,223评论 0 2
  • 转至元数据结尾创建: 董潇伟,最新修改于: 十二月 23, 2016 转至元数据起始第一章:isa和Class一....
    40c0490e5268阅读 1,775评论 0 9
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile丽语阅读 3,858评论 0 6
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,766评论 18 399