swift - 如何获得Realm中最具代表性的值(value)?

标签 swift filter count realm realm-cocoa

我对 iOS 上的 Realm 有疑问。

我的 Realm 数据库中有一个对象,如下所示:

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?

谢谢

最佳答案

Realm 没有完全可以做到这一点的 native 查询,但您可以将 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"

关于swift - 如何获得Realm中最具代表性的值(value)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37036628/

相关文章:

swift - AVPlayer,视频结束后黑屏

javascript - 具有多个值的表过滤

count - flink 表统计具有相同条目的行数

ios - 如何知道 UITableView 何时完成 reloadData?

ios - iOS 应用程序的 Podfile 使用

search - Solr 过滤器查询,包括 NOT 和 OR

python - 基于列向量制作 Pandas 面具

值不相等时MySQL计数

MySQL - 当指定 HAVING 时使用 COUNT() 返回总结果

ios - 如何解析和访问 HTTPresponse 中的特定数据