SUBQUERY in NSPredicate and NSInvalidArgumentException

前端 未结 2 703
孤独总比滥情好
孤独总比滥情好 2020-12-19 10:33

I set up the following model in Core Data.

Book has a to-many relationship, called toBookOrders, with OrderBook entity. The inverse is called toBook.
Book ha         


        
相关标签:
2条回答
  • 2020-12-19 11:12

    Separate the isSync == 0 and SUBQUERY into separate NSPredicates, add them to an NSArray then use [NSCompoundPredicate andPredicateWithSubpredicates:array] to get them joined into a single one to pass to your NSFetchSpecification.

    0 讨论(0)
  • 2020-12-19 11:22

    Here's the crux of your problem:

    @"isSync == 0 AND SUBQUERY(toBookOrders, $x, $x.toBook == SELF)"
    

    If you split that up into the two subpredicates, as Scott suggests, you'll get:

    • isSync == 0
    • SUBQUERY(toBookOrders, $x, $x.toBook == SELF)

    The problem is that every SUBQUERY does not return true or false, as a predicate must. It returns a collection (an array), and an array is not the same thing as true or false. Thus, when you create the predicate, you're getting an error that it's an invalid format, because the stuff after the AND isn't a predicate. It's simply an expression.

    You're probably wanting:

    @"isSync == 0 AND SUBQUERY(toBookOrders, $x, $x.toBook == SELF).@count > 0"
    

    This would give you a predicate to find all the books where isSync is false and the at least one of the Book's OrderBooks is that Book.

    0 讨论(0)
提交回复
热议问题