2017-01-06 77 views
1

我已經創建了一個使用sqlite.swift將json數據映射到sqlite存儲的函數。我收到奇怪的行爲,雖然自第一次嘗試運行插入我得到一個「沒有這樣的表」錯誤「。但插入後工作完美的初始拋出。我的代碼通過使用SQLData連接到數據庫onload .instance.connect(),然後每次調用insert時間把它初始化表,以確保它在數據中設置了所有列。Sqlite.swift沒有這樣的表錯誤

//附加到按鈕

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

回答

0

更改連接負離子功能如下

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

和BU確保您.sqlite3(或.db的)文件到您的項目層次結構和複製捆綁資源,如圖像

enter image description here

enter image description here