0

我对 iOS 上的 Realm 有疑问。

我的 Realm DB 中有一个对象,如下所示:

class MyObject: Object {
    dynamic var id: Int!
    dynamic var val: String!
}

假设我用这些数据填充我的表:

| id | val |
|----|-----|
| 1  | A   |
| 2  | B   |
| 3  | A   |
| 4  | B   |
| 5  | A   |
| 6  | A   |

如何查询我的 Realm DB 以返回代表最多的值 A?

谢谢

4

1 回答 1

1

Realm 没有可以完全做到这一点的本机查询,但是您可以将 Realm 的 KVC 支持与NSCountedSet结合起来相当容易地实现这一点:

import Foundation
import RealmSwift

class MyObject: Object {
    dynamic var id: Int = 0
    dynamic var val: String = ""
}

let realm = try! Realm()
try! realm.write {
    for (index, value) in ["A", "B", "A", "B", "A", "A"].enumerate() {
        realm.create(MyObject.self, value: [index, value])
    }
}

let values = realm.objects(MyObject).valueForKey("val") as! [AnyObject]
let countedSetOfValues = NSCountedSet(array: values)
let maxElement = countedSetOfValues.allObjects.maxElement { first, second in
    return countedSetOfValues.countForObject(first) < countedSetOfValues.countForObject(second)
}
maxElement // => "A"
于 2016-05-05T14:26:43.320 回答