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
        }
    }
}

}

你可能感兴趣的:(swift数据库封装)