2

我想知道在 realm.io (swift)中是否有可能从一个“表”中选择不在另一个“表”中的所有项目。

假设您有 2 个课程:

class A: Object {
    dynamic var id: Int = 0
    dynamic var text: String = ""
}

class B: Object {
    dynamic var id: Int = 0
    dynamic var value: Bool = false
}

是否有可能从 B 中不存在 id 的 A 获得项目的结果?

4

1 回答 1

3

实际上有一个非常简单的方法可以使用NSPredicateRealm 过滤器 API 来做到这一点。

func fetch() throws -> [A] {
        do {
            // Create Realm
            let realm = try Realm()

            // Get B objects from Realm and put their IDs to [Int] array
            let IdB: [Int] = realm.objects(B).map { $0.id }

            // Create predicate
            // Filter all items where property id is not present in array IdB
            let predicateFilter = NSPredicate(format: "NOT (id IN %@)", IdB)

            // Get all A objects from array using predicateFilter
            let objectsA = realm.objects(A).filter(predicateFilter)

            // Return the [A] array
            return objectsA.map { $0 }
        } catch {

            // Throw an error if any
            throw error
        }

}

另请注意,使用 Realm 获取的所有对象都是延迟加载的,这意味着此方法也非常快。从文档中:

Realm 中的所有查询(包括查询和属性访问)都是惰性的。只有在访问属性时才会读取数据。

于 2016-06-06T12:55:15.833 回答