是否有 NSPredicate 来过滤具有一对多关系的模型(过滤许多)?
Is there a NSPredicate to filter models with one-to-many relationship (filter the many)?
我有两个模型:专辑和歌曲,专辑包含N首歌曲,但歌曲只包含1张专辑。我正在尝试制作一个特定的过滤器,但找不到能给我预期结果的 NSPredicate。
我在 CoreData 上创建了两个模型:
所以我创建了一些对象:
let song1 = Song(context: context)
song1.name = "I Love You"
song1.composer = "Ana"
let song2 = Song(context: context)
song2.name = "Hello And Goodbye"
song2.composer = "Ben"
let song3 = Song(context: context)
song3.name = "I Miss You"
song3.composer = "Marie"
let song4 = Song(context: context)
song4.name = "Lonely"
song4.composer = "Ana"
let album = Album(context: context)
album.name = "Love Songs 1"
let set = NSSet(array: [song1, song2, song3])
album.addToSong(set)
let album2 = Album(context: context)
album2.name = "Love Songs 2"
let set2 = NSSet(array: [song4])
album2.addToSong(set2)
所以,我想做这个过滤器:
获取安娜作曲且歌曲名称包含 "n"
的专辑
我正在使用此谓词获取相册模型:
let composerPredicate = NSPredicate(format: "ANY song.composer = %@", "Ana")
let songPredicate = NSPredicate(format: "ANY song.name contains %@", "n")
let compoundPredicate = NSCompoundPredicate(andPredicateWithSubpredicates: [composerPredicate, songPredicate])
但是在获取的结果中我得到了两张专辑,但我只想 return 我 "Love Songs 2"。
你知道我该怎么做吗?
EDIT1: 我想找到一个不使用任何映射、过滤器或循环(如果可能的话)的解决方案,因为它直接影响性能,因为我处理大量数据。
您需要使用 SUBQUERY,因为您希望仅在专辑中有一首符合这两个条件的歌曲时才包含该专辑。 (您的复合谓词将包括一张专辑,其中一首歌曲符合第一个标准,另一首歌曲符合第二个标准)。
let predicate = NSPredicate(format: "SUBQUERY(song, $S, $S.composer == %@ AND $S.name contains %@).@count > 0", “Ana”, "n")
我有两个模型:专辑和歌曲,专辑包含N首歌曲,但歌曲只包含1张专辑。我正在尝试制作一个特定的过滤器,但找不到能给我预期结果的 NSPredicate。
我在 CoreData 上创建了两个模型:
所以我创建了一些对象:
let song1 = Song(context: context)
song1.name = "I Love You"
song1.composer = "Ana"
let song2 = Song(context: context)
song2.name = "Hello And Goodbye"
song2.composer = "Ben"
let song3 = Song(context: context)
song3.name = "I Miss You"
song3.composer = "Marie"
let song4 = Song(context: context)
song4.name = "Lonely"
song4.composer = "Ana"
let album = Album(context: context)
album.name = "Love Songs 1"
let set = NSSet(array: [song1, song2, song3])
album.addToSong(set)
let album2 = Album(context: context)
album2.name = "Love Songs 2"
let set2 = NSSet(array: [song4])
album2.addToSong(set2)
所以,我想做这个过滤器:
获取安娜作曲且歌曲名称包含 "n"
的专辑我正在使用此谓词获取相册模型:
let composerPredicate = NSPredicate(format: "ANY song.composer = %@", "Ana")
let songPredicate = NSPredicate(format: "ANY song.name contains %@", "n")
let compoundPredicate = NSCompoundPredicate(andPredicateWithSubpredicates: [composerPredicate, songPredicate])
但是在获取的结果中我得到了两张专辑,但我只想 return 我 "Love Songs 2"。
你知道我该怎么做吗?
EDIT1: 我想找到一个不使用任何映射、过滤器或循环(如果可能的话)的解决方案,因为它直接影响性能,因为我处理大量数据。
您需要使用 SUBQUERY,因为您希望仅在专辑中有一首符合这两个条件的歌曲时才包含该专辑。 (您的复合谓词将包括一张专辑,其中一首歌曲符合第一个标准,另一首歌曲符合第二个标准)。
let predicate = NSPredicate(format: "SUBQUERY(song, $S, $S.composer == %@ AND $S.name contains %@).@count > 0", “Ana”, "n")