Reputation: 1251
How do i query the size of a realm object that is within another realm object
I have two realm classes Competition
& User
. User
is a realm class also contained in Competition
:
open class Competition (@PrimaryKey var competitionId: String?=null,
var user: User? =null): RealmObject()
open class User(@PrimaryKey var userId: String?=null,
var name: String? =null): RealmObject()
At some point, i would like to get the size of User within a specific competitionId in Competition and i'm having a challenge with what i thought would be trivial
Here is what i have tried
var userObj = realm.where<Competition>().equalTo(
"competitionId", competitionId
).findFirst().user.realm.where<User>().findAll().size
This gives me a
kotlin.KotlinNullPointerException
Stacktrace:
2019-03-12 16:03:25.112 22028-22028/co.keepnet.bass W/System.err: kotlin.KotlinNullPointerException
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at co.keepnet.bass.ui.MainActivity$onClick$1.execute(MainActivity.kt:41)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at io.realm.Realm.executeTransaction(Realm.java:1431)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at co.keepnet.bass.ui.MainActivity.onClick(MainActivity.kt:37)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at co.keepnet.bass.data.adapter.CompetitionsAdapter$onBindViewHolder$1.onClick(CompetitionsAdapter.kt:75)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at android.view.View.performClick(View.java:6897)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at android.view.View$PerformClick.run(View.java:26101)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at android.os.Handler.handleCallback(Handler.java:789)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at android.os.Handler.dispatchMessage(Handler.java:98)
2019-03-12 16:03:25.113 22028-22028/co.keepnet.bass W/System.err: at android.os.Looper.loop(Looper.java:164)
2019-03-12 16:03:25.114 22028-22028/co.keepnet.bass W/System.err: at android.app.ActivityThread.main(ActivityThread.java:6944)
2019-03-12 16:03:25.114 22028-22028/co.keepnet.bass W/System.err: at java.lang.reflect.Method.invoke(Native Method)
2019-03-12 16:03:25.114 22028-22028/co.keepnet.bass W/System.err: at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:327)
2019-03-12 16:03:25.114 22028-22028/co.keepnet.bass W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1374)
Upvotes: 1
Views: 622
Reputation: 81539
I mean, it is fairly trivial, if you use Realm's features to your advantage (3.5.0+, I think).
open class User(): RealmObject() {
@PrimaryKey var userId: String? = null
var name: String? = null
@LinkingObjects("user")
val userOfCompetitions: RealmResults<Competition>? = null
}
Then
val userCount = realm.where<User>()
.equalTo("userOfCompetitions.competitionId", competitionId)
.count()
Upvotes: 2