美文网首页
swift数据库封装

swift数据库封装

作者: heigo | 来源:发表于2017-02-28 22:54 被阅读0次

    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数据库封装

          本文链接:https://www.haomeiwen.com/subject/fybfgttx.html