Sqlite.swift нет такой ошибки таблицы

Я создал функцию для отображения данных JSON в хранилище sqlite с помощью sqlite.swift. Я получаю странное поведение, хотя с первого раза, когда я пытаюсь запустить вставку, я получаю сообщение об ошибке "Нет такой таблицы". Но вставки прекрасно работают после этого начального выброса. Мой код работает, устанавливая соединение с базой данных с помощью SQLData.instance.connect(). Затем каждый раз, когда вызывается вставка, он инициализирует таблицу, чтобы убедиться, что она настроена со всеми столбцами в данных.

// прикреплен к кнопке

let userJSON = JSON(["user_id" : id, "username" : email])

SQLData.instance.insert(table: "users", data: userJSON) { result in
        if let result = result{
                print(result)
        }
}

//sql class

class SQLData {
    static let instance = SQLData()
    var db: Connection? = nil

    func connect() {
        let path = NSSearchPathForDirectoriesInDomains(
            .documentDirectory, .userDomainMask, true
            ).first!
        do {
            self.db = try Connection("\(path)/contacts.sqlite3")
            if let db = self.db {
                try db.run(Table("users").drop(ifExists: true))
            }
            print("SQLite connection established.")
        } catch {
            print("Couldn't create SQLite connection.")
        }
    }

    func initTable(table: String, data: JSON, completionHandler: (Table?) -> Void){
        if let db = db {
            let t = Table(table)

            do {
                try db.run(t.create(temporary: false, ifNotExists: true) { r in
                    r.column(Expression<Int>("id"), primaryKey: true)
                    r.column(Expression<Bool>("synced"), defaultValue: false)

                    for (key,val) in data {
                        if val.bool != nil{
                            r.column(Expression<Bool>(key), defaultValue: false)
                        } else if val.int != nil {
                            r.column(Expression<Int>(key), defaultValue: 0)
                        } else if val.double != nil {
                            r.column(Expression<Double>(key), defaultValue: 0.0)
                        } else {
                            r.column(Expression<String?>(key), defaultValue: "")
                        }
                    }
                    completionHandler(t)
                })
            } catch let err {
                print(err)
                completionHandler(nil)
            }
        } else {
            completionHandler(nil)
        }
    }

    func insert(table: String, data: JSON, completionHandler: @escaping (Int64?) -> Void){
        self.initTable(table: table, data: data) { t in
            if let db = db, let t = t {
                var query: [Setter] = []
                for (key, val) in data {
                    if val.bool != nil{
                        query.append(Expression<Bool>(key) <- val.boolValue)
                    } else if val.int != nil {
                        query.append(Expression<Int>(key) <- val.intValue)
                    } else if val.double != nil {
                        query.append(Expression<Double>(key) <- val.doubleValue)
                    } else {
                        query.append(Expression<String?>(key) <- val.stringValue)
                    }
                }
                do {
                    try db.transaction {
                        let insert = t.insert(query)
                        let rowid = try db.run(insert)
                        completionHandler(rowid)
                    }
                } catch let err {
                    print(err)
                    completionHandler(nil)
                }
            } else {
                completionHandler(nil)
            }
        }
    }
}

1 ответ

Измените функцию подключения, как показано ниже

func connect(){
    do {
        let databaseFilePath = Bundle.main.path(forResource: "contacts", ofType: "sqlite3")!
        db = try Connection(databaseFilePath)
    } catch {
        print(error)
    }
}

и убедитесь, что файл.sqlite3 (или.db) добавлен в иерархию проекта и скопируйте ресурсы пакета, например изображения

введите описание изображения здесь

введите описание изображения здесь

Другие вопросы по тегам