过滤领域对象以仅按属性获取一个(不同的)对象

Posted

技术标签:

【中文标题】过滤领域对象以仅按属性获取一个(不同的)对象【英文标题】:Filter realm objects to only get one (distinct) object by attribute 【发布时间】:2018-02-12 08:59:07 【问题描述】:

让我先解释一下,因为标题可能有点混乱。

假设我有这个电影类型的领域对象:

Movie1(id: 0, genre: "horror")

Movie2(id: 1, genre: "horror")

Movie3(id: 3, genre: "sci-fi")

我需要做的是为每种类型获得第一名(在本例中为 Movie1Movie3

我想只使用realm + NSPredicate 不使用循环,所以性能更好,但我有点卡在那里......

到目前为止,我得到的是这样的:

Realm().objects(Movie.self).sorted(byKeyPath: id, ascending: true)
.value(forKeyPath: "@distinctUnionOfObjects.genre") 

这将返回一个带有("horror", "sci-fi") 的数组,我真的不知道下一步应该是什么。如果我尝试做一个:

 .filter("genre IN %@", arrayWithDistinctGenres) 

它会返回我所有的对象。

可能很简单,但我不知道该怎么做。

感谢任何帮助。

【问题讨论】:

【参考方案1】:

从 Realm Swift 3.1 开始,您可以使用 let movies = realm.objects(Movie.self).sorted(by: ["id", true]).distinct(by: ["genre"]),这将使用在 distinct 操作之前应用的排序顺序选择每个流派的第一个 Movie

【讨论】:

是的,有效。非常感谢伙计。我使用的是 3.0.1 领域,但在更新到 3.1.1 后它工作了,为我节省了一些代码行并避免了 for 循环。谢谢!【参考方案2】:

您需要一次按一种类型进行过滤。像这样的

let genres = realm.objects(Genres.self)
let movies = realm.objects(Movie.self).sorted(byKeyPath: id, ascending: true)

for genre in genres 
    let firstInThisGenre = movies.filter( $0.genreId == genre.id ).first

【讨论】:

是的,这就是我现在所拥有的,我想避免(如果可能的话)那个循环。我想那是不可能的,谢谢。 使用 mysql 之类的东西,您可以在查询中使用 GROUP BY 来执行此操作而无需循环,但我认为这在领域中是不可能的 好的。再次感谢

以上是关于过滤领域对象以仅按属性获取一个(不同的)对象的主要内容,如果未能解决你的问题,请参考以下文章

领域过滤结果列表中的空对象

在领域中创建对对象的引用的正确方法

spring中怎么实现过滤器和监听器?

为啥不同的机器学习领域都可以使用CNN,CNN解决了这些领域的哪些共性问题?是如何解决的?

通过其字段的不同值对Realm对象进行分组

针对不同对象的多个领域查询