我对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?
由于
答案 0 :(得分: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"