簡體   English   中英

如何使用NSPredicate過濾核心數據關系?

[英]How can I use NSPredicate to filter on core data relationships?

假設我有“obj”類型的核心數據對象,它具有屬性“propertyA”和與“sub”類型的對象的一對多關系,該對象具有兩個屬性“propertyB”和“propertyC”。

我想獲取propertyA等於一個值的所有objs和一個帶有propertyB和propertyC set的子obj。

如果它只是propertyA和propertyB,我會這樣做

[NSPredicate predicateWithFormat:@"ANY sub.propertyB = %@ AND propertyA == %@", ...];

問題是我無法弄清楚如何添加第二個屬性。 我只想要至少有一個具有兩個屬性為true的子的obj。 我嘗試了以下,但它不起作用:

[NSPredicate predicateWithFormat:@"ANY (sub.propertyB = %@ AND sub.propertyC) AND propertyA == %@", ...];

我已經嘗試過沒有ANY,但這也不起作用。 我怎樣才能做到這一點?

由於您與子對象具有多對多關系,因此objsubs屬性返回一個集合而不是單個對象。 要查詢集合,您需要使用SUBQUERY。

子查詢具有以下形式:

SUBQUERY(collection, $individualCollectionItem, expression-with-collection-item)

在這種情況下,你會想要類似的東西

SUBQUERY(subs,$s,$s.propertyB==%@) AND SUBQUERY(subs,$s,$s.propertyC!=NULL)

解決方案似乎是:

[NSPredicate predicateWithFormat:@"propertyA == %@ AND (SUBQUERY(sub, $s, $s.propertyB == %@ AND $s.propertyC == %@).@count != 0)",  propertyAvalue, propertyBvalue, propertyCvalue];

最后的值是您希望各種屬性等於的值。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM