2017-07-06 3 views
1

Mon code est le suivant:Sqlite.Swift Ambigu Nom de la colonne Swift

let assetTag = Expression<String>("asset_tag") 


let query2 = mdm.select(mdm[assetTag],os, mac, lastReported) 
       .filter(mdm[assetTag] != "ipad" && location == facility) 
       .order(mdm[assetTag]) 
       .join(mdm, on: ewp[assetTag] == mdm[assetTag]) 



      let results2 = try! db.prepare(query2) 

Je reçois une erreur qui dit:

fatal error: 'try!' expression unexpectedly raised an error: ambiguous column name: mdm.asset_tag (code: 1): file /Library/Caches/com.apple.xbs/Sources/swiftlang/swiftlang-802.0.53/src/swift/stdlib/public/core/ErrorType.swift, line 182

Ma base de données a deux tables, l'une appelée PTe et un appelé MDM . Les deux ont une colonne appelée asset_tag donc j'ai pensé en faisant mdm [assetTag] qui sélectionnerait le bon mais il jette toujours l'erreur.

EDIT

Toujours incapable de résoudre le problème. Je crée mes tableaux comme suit:

let db = try Connection("\(path)/db.sqlite3") 

     try db.run(ewp.create { t in 
      t.column(assetTag) 
      t.column(location) 
      t.column(deviceStatus) 

     }) 

     try db.run(mdm.create { t in 
      t.column(assetTag) 
      t.column(os) 
      t.column(mac) 
      t.column(lastReported) 

     }) 

    } 

Pour une raison quelconque, mdm [AssetTag] dit toujours la colonne est ambiguë, mais Theres seulement 1 colonne comme ça.

Répondre

0

J'ai trouvé la réponse. Je rejoignais la table mdm sur elle-même. J'avais besoin de changer la jointure à:

.join(ewp, on: ewp[assetTag] == mdm[assetTag])