Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to perform Realm count query

How can I do a count query on Realm?

for example this is my model

class Dog: Object {
  dynamic var name = ""
}
class Person: Object {
  dynamic var name = ""

  let dogs = List<Dog>()
}

I want to fetch all persons with at least one dog something like

Realm().objects(Person).filter("dogs.@count > 0")

but @count isn't supported as i understand

like image 581
Mario Avatar asked Aug 09 '15 16:08

Mario


2 Answers

Yes, Realm still does not support .@count query. You can work around that you modify the Person model to have a count property. Then you update the count property when you append a dog object to the dogs array.

This feature request is tracked by Issue #1166 https://github.com/realm/realm-cocoa/issues/1166

Update

Realm supports @count and other collection queries from v0.96.

like image 128
kishikawa katsumi Avatar answered Sep 18 '22 13:09

kishikawa katsumi


The syntax for the new aggregate expressions (@count, @min, @max, @sum, @avg) for Results and List looks like this:

realm.objects(Person.self).filter("dogs.@count > 0")
like image 27
Simon Bengtsson Avatar answered Sep 17 '22 13:09

Simon Bengtsson