列出项目
所以我试图在Swift中设置一个具有多个条件的请求。 SQL等同于:
select BOARDID
from BOARD
where BOARDID not like "someBoard"
and BOARDID not like "anotherBoard"
..
我有一个字符串数组,我正在尝试遍历每个字符串以创建subPredicate,将其添加到compoundPredicate,然后使用该compoundPredicate创建一个获取请求:
let openBoards = ["someBoard", "anotherBoard", "etc"],
request = NSFetchRequest(entityName: "Board")
var openBoardsSubPredicates: Array = [],
error: NSError? = nil
for board in openBoards {
var subPredicate = NSPredicate(format: "boardID not like '\(board)'")
openBoardsSubPredicates += subPredicate
}
request.predicate = NSCompoundPredicate.andPredicateWithSubpredicates(openBoardsSubPredicates)
但是,它在var subPredicate线上失败了。
谢谢!
答案 0 :(得分:1)
错误告诉您问题所在。您提供的格式不是有效格式。具体来说,没有"不喜欢"比较。你必须做"不是"外:
NSPredicate(format: "not (boardID like %@)", board)
正如下面提到的@MartinR,你可以让NSPredicate自动转义特殊字符,这样它们就不会通过插入变量而不是使用字符串插值来干扰谓词。