Запрашивать размер подобъекта класса Realm — Kotlin

#android #kotlin #realm

#Android #kotlin #realm

Вопрос:

Как мне запросить размер объекта realm, который находится внутри другого объекта realm

У меня есть два класса realm Competition amp; User . User класс realm также содержится в 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()
  

В какой-то момент я хотел бы получить размер User в пределах определенного competitionId в Competition, и у меня возникла проблема с тем, что, как я думал, было бы тривиальным

Вот что я пробовал

 var userObj = realm.where<Competition>().equalTo(
                "competitionId", competitionId
            ).findFirst().user.realm.where<User>().findAll().size
  

Это дает мне

котлин.Исключение KotlinNullPointerException

Отслеживание стека:

 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)
  

Комментарии:

1. Не могли бы вы вставить всю трассировку стека?

2. Я добавил трассировку стека

Ответ №1:

Я имею в виду, что это довольно тривиально, если вы используете возможности Realm в своих интересах (я думаю, 3.5.0 ).

 open class User(): RealmObject() {
    @PrimaryKey var userId: String? = null

    var name: String? = null

    @LinkingObjects("user")
    val userOfCompetitions: RealmResults<Competition>? = null
}
  

Затем

 val userCount = realm.where<User>()
                     .equalTo("userOfCompetitions.competitionId", competitionId)
                     .count()
  

Комментарии:

1. Пожалуйста, просветите меня здесь. Итак, когда я использую var userObj = realm.where<Competition>().equalTo( "competitionId", competitionId ).findFirst().user , почему я получаю null, почему я не могу получить доступ к этому объекту? Приведенный выше метод немного сбивает с толку

2. Похоже, что у извлеченного вами конкурса не было пользователя, установленного в качестве значения поля.

3. В любом случае, «вышеуказанный метод» является правильным способом сделать это.

4. Действительно, это так. Я также просмотрел эту ссылку на статью, которая также, оказывается, была написана вами. Это хорошо объясняет, спасибо

5. Я рад, что вы нашли мою статью полезной! 😀