Ios 使用事务插入正在抛出错误Sqlite.swift

Ios 使用事务插入正在抛出错误Sqlite.swift,ios,swift,sqlite,swift3,sqlite.swift,Ios,Swift,Sqlite,Swift3,Sqlite.swift,我创建了一个数据库类,如下所示: class Database { static let instance = Database() private let categories = Table("Category") private var db: Connection? let cat_id = Expression<String>("id") let cat_name = Expression<String>("name")

我创建了一个数据库类,如下所示:

class Database {
    static let instance = Database()
    private let categories = Table("Category")
    private var db: Connection?

    let cat_id = Expression<String>("id")
    let cat_name = Expression<String>("name")


    private init() {
        let path = NSSearchPathForDirectoriesInDomains(
            .documentDirectory, .userDomainMask, true
            ).first!
        do {
            db = try Connection("\(path)/SalesPresenterDatabase.sqlite3")
            createTable()
        } catch {
            print("error")
        }
    }
    func createTable() {
        do{
            try self.db!.run(self.categories.create(ifNotExists: true) { table in
                table.column(self.cat_id)
                table.column(self.cat_name)
            })
        }catch{
             print("error")
        }
    }

    func addRow(table: DBTableNames, object: [Any]) -> Int64? {
      do {
         try self.db!.transaction() {
            for obj in object{
                if table.rawValue == DBTableNames.Category.rawValue{
                    let cats : CategoryObject = obj as! CategoryObject
                    let insert = self.categories.insert(self.cat_id <- cats.id,
                                                        self.cat_name <- cats.name)
                    try self.db!.run(insert)

                }
             }
          }
        }catch{
           print("Insert failed \(error)")
           return -1
        }
        return 1
         }
}
我的问题是,它总是抛出一个错误,说:

插入失败。操作无法完成。(SQLite.Result) 错误0.)和完整:无法回滚-没有活动的事务(代码: (一)

如果我再看到这个错误一次,我的Mac电脑就会从窗口消失

整个操作都在后台线程中,但我也尝试了以下操作:

    DispatchQueue.main.async{
    let returnValue = Database.instance.addRow(table: DBTableNames(rawValue: entity)!,
                                                   object: databaseObject)
}
它不起作用。这是没有意义的,因为我还尝试在事务中创建表,而且效果非常好


任何帮助都将不胜感激

您的
func createTable()
func addRow()
方法不是线程安全的。多个线程可以同时访问它


在Singleton类中创建一个私有串行
DispatchQueue
,并通过该串行队列执行上述功能。这将阻止同时从多个线程访问数据库,串行队列将对并发任务进行排队。

在操场上运行此操作时会发生什么?好的,我开始认为这是线程问题。我可以让它独立于其他代码工作。现在,我没有说明的一点是,代码是从Alamofire完成块执行的……是的,或者使用SQLite库为您完成所有困难的线程工作:
    DispatchQueue.main.async{
    let returnValue = Database.instance.addRow(table: DBTableNames(rawValue: entity)!,
                                                   object: databaseObject)
}