SQLite.Swift:无法使用类型'(Setter,Setter,Setter)'的参数列表调用'insert'

时间:2015-08-10 07:02:23

标签: ios sqlite sqlite.swift

好的,经过一些试验和错误后,我设法消除了一些其他错误,尽管我仍然遇到一个问题,返回上述错误。该行是:

PCharacter.PCharacters.insert(PCharacter.charName <- "\(newCharName)", 
    PCharacter.maxHP <- "\(newCharHP)", PCharacter.maxMP <- "\(newCharMP)")

据我所知,这遵循insert命令的格式,除了Github上的示例使用硬编码值而不是变量,尽管我需要变量,因为用户输入它们。

只是为了提供更多背景知识:PCharacter是AppDelegate中的一个结构体,而这是一个包含在链接到ViewController中按钮的Action中的命令。

这是PCharacter结构:

struct PCharacter {
    static let PCharacters = db["PCharacters"]
    static let id = Expression<Int64>("id")
    static let charName = Expression<String>("charName")
    static let currentHP = Expression<Int64>("currentHP")
    static let maxHP = Expression<Int64>("maxHP")
    static let currentMP = Expression<Int64>("currentMP")
    static let maxMP = Expression<Int64>("maxMP")
    static let currentExp = Expression<Int64>("currentExp")
    static let nextExp = Expression<Int64>("nextExp")
    static let charWeaponID = Expression<Int64>("charWeaponID")

    static func createTable() {
        db.create(table: PCharacters) { t in
            t.column(id, primaryKey: .Autoincrement)
            t.column(charName, unique: true)
            t.column(currentHP)
            t.column(maxHP)
            t.column(currentMP)
            t.column(maxMP)
            t.column(currentExp)
            t.column(nextExp)
            t.foreignKey(charWeaponID, references: Weapon.Weapons[id], delete: .SetNull)
        }
    }
}

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

有一个section of the Contributing Guidelines可以涵盖这个确切的错误。如果您将insert拆分为多行,则可以在以下两行中删除正确的错误消息:

PCharacter.maxHP <- "\(newCharHP)"
PCharacter.maxMP <- "\(newCharMP)"
  

二元运算符'&lt; - '不能应用于'Expression'和'String'类型的操作数

您的maxHPmaxMP列为Int64,但您将其设置为字符串值。确保newCharHPnewCharMP都是Int64