0

我使用SQLite.swift并想替换语句中的问号。这可以为这样的单个条目完成:

let stmt = db.prepare("INSERT INTO users (email) VALUES (?)")
for email in ["betty@icloud.com", "cathy@icloud.com"] {
    stmt.run(email)
}

我没有看到如何执行以下操作来使用如下数组:

var values:[String] = ["test1","test2", "test3"]

在如下声明中:

let stmt = db.prepare("SELECT * from users where email in (?)")

以下不起作用:

stmt.run(values)

如何使用 NSArray 作为语句的参数?

4

1 回答 1

1

如果您使用的是类型安全层,则可以使用contains()

users.filter(contains(["test1", "test2"], email))

// the above assumes this boilerplate precedes it:
let email = Expression<String>("email")
let users = db["users"]

如果您使用的是原始 SQLite3 API,它不支持数组,因此您需要自己格式化:

let emails = ["test1", "test2"]
let template = join(", ", [String](count: count(emails), repeatedValue: "?"))
let stmt = db.prepare(
    "SELECT * FROM users WHERE email IN (\(template))", emails
)
于 2015-04-16T17:04:57.003 回答