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
}
}
}
}
网友评论