0

我有Json我想用来映射Moshi和存储的东西Room

{
    "name": "My Group",
    "members": [
        {
            "id": "119075",
            "invitedUser": {
                "id": 97375,
                "email": "xxx@gmail.com"
            },
            "inviting_user": {
                "id": 323915,
                "email": "yyy@gmail.com"
            }
        },
        {
            "id": "395387",
            "invitedUser": {
                "id": 323915,
                "email": "aaa@gmail.com"
            },
            "inviting_user": {
                "id": 323915,
                "email": "bbb",
            }
        }
    ]
}

我准备了我的模型

@Entity(tableName = "groups")
data class Group(
    @PrimaryKey
    val id: Long,
    val members: List<Member>
)

@Entity(tableName = "members")
data class Member(
    @PrimaryKey
    val id: Long,

    @Json(name = "invited_user")
    @ColumnInfo(name = "invited_user")
    val invitedUser: User,

    @Json(name = "inviting_user")
    @ColumnInfo(name = "inviting_user")
    val invitingUser: User
)

@Entity(tableName = "users")
data class User(
    @PrimaryKey
    val id: Int,

    val email: String
)

目前,我已error: Cannot figure out how to save this field into database. 阅读此https://developer.android.com/training/data-storage/room/relationships。但是,如果我要像文档中那样对关系建模,我不知道如何让 Moshi 映射关系?你找到解决这个问题的最简单的方法了吗?

4

3 回答 3

2

在我看来,你有两个选择。

  1. 您将组和用户拆分为单独的表并分别插入。
  2. 您用于TypeConverters将成员存储为组的字段。

您的实现将取决于您的用例。

于 2020-04-04T10:17:13.993 回答
1

最后,我使用TypeConverters

private val membersType = Types.newParameterizedType(List::class.java, Member::class.java)
private val membersAdapter = moshi.adapter<List<Member>>(membersType)

@TypeConverter
fun stringToMembers(string: String): List<Member> {
    return membersAdapter.fromJson(string).orEmpty()
}

@TypeConverter
fun membersToString(members: List<Member>): String {
    return membersAdapter.toJson(members)
}

那是我的模型

@TypeConverters(Converters::class)
@Entity(tableName = "groups")
data class Group(
    @PrimaryKey
    val id: Long,
    val name: String
) {
    companion object {

        data class Member(
            val id: Long,
            val invitedUser: User,
            val invitingUser: User
        )

        data class User(
            val id: Long,
            val email: String
        )
    }
}

它看起来对你好吗?可能更干净的是只有 id 并将用户存储在其他地方,但我喜欢这个解决方案非常简单。

于 2020-04-04T21:08:51.283 回答
0
  1. 您用于TypeConverters将成员存储为组的字段。

我相信这是您需要的实施。

open class UserRequestConverter {

    private val moshi = Moshi.Builder().build()

    @TypeConverter
    fun fromJson(string: String): User? {
        if (TextUtils.isEmpty(string))
            return null

        val jsonAdapter = moshi.adapter(User::class.java)
        return jsonAdapter.fromJson(string)
    }

    @TypeConverter
    fun toJson(user: User): String {
        val jsonAdapter = moshi.adapter(User::class.java)
        return jsonAdapter.toJson(user)
    }
}



@Entity(tableName = "members")
data class Member(
    @PrimaryKey
    val id: Long,

    @Json(name = "invited_user")
    @ColumnInfo(name = "invited_user")
    @TypeConverters(UserRequestConverter::class)
    val invitedUser: User,

    @Json(name = "inviting_user")
    @ColumnInfo(name = "inviting_user")
    @TypeConverters(UserRequestConverter::class)
    val invitingUser: User
)
于 2020-04-04T11:22:27.533 回答