Return unique/distinct 值与 Realm 查询

Return unique/distinct values with Realm query

我有一个 Message/RLMObject 模型,它有一个 NSString *jabberID property/row,我想检索该行中的每个 unique 值。

换句话说,我想从我的 Message 模型中检索非重复的 jabberID 值。谁能帮忙解决这个问题?

我使用核心数据的方式是在 NSFetchRequest 上使用 returnsDistinctResults 设置。

我发现 Realm 还不完全支持不同的查询。好消息是我也找到了解决方法,在 github issue.

Objective-c

RLMResults *messages = [Message allObjects];
NSMutableArray *uniqueIDs = [[NSMutableArray alloc] init];
NSMutableArray *uniqueMessages  = [[NSMutableArray alloc] init];
for (Message *msg in messages) {
    NSString *jabberID = msg.jabberID;
    Message *uniqueMSG = (Message *)msg;
    if (![uniqueIDs containsObject:jabberID]) {
        [uniqueMessages addObject:uniqueMSG];
        [uniqueIDs addObject:jabberID];
    }
}

Swift 3.0

let realm = try! Realm()
let distinctIDs = Set(realm.objects(Message.self).value(forKey: "jabberID") as! [String])
var distinctMessages = [Message]()
for jabberID in distinctIDs {
    if let message = realm.objects(Message.self).filter("jabberID = '\(jabberID)'").first {
        distinctMessages.append(message)
    }
}

Swift 以来的函数式编程方法,Realm 延迟加载;不是 easy/available Objective-C 中的解决方案,而是至少 Swift 中的解决方案: Swift

let distinctTypes = reduce(Realm().objects(User), []) { [=10=] + (!contains([=10=], .type) ? [.type] : [] ) }

更新:

Swift reduce 是一种性能密集型,分配一堆中间数组,而不是以下应该更好的性能明智,但必须显式转换

let distinctTypes = Array(Set(Realm().objects(User).valueForKey("type") as! [String]))