ROOM无法弄清楚如何将该字段保存到数据库中

时间:2019-04-05 14:59:14

标签: android kotlin android-room

我需要你的帮助。 我尝试在不进行反序列化的情况下找到解决方案,但没有发现任何问题。 如果您能帮助我,那就太好了... 所以我有这个以下JSON文件

"resources": [{
    "id": 441988,
    "name": "TVA",
    "parent": {
      "id": 159
    },
  },
  {
    "id": 441900,
    "name": "Marketing",
    "parent": {
      "id": 166
    },
}]

我用ROOM创建了一个数据库,它可以工作,但是我有一个问题, 无法保存“父对象的ID”

这是我的以下代码:

    @Entity(tableName = "resources")
    class CategoryBean {

    @PrimaryKey
    @ColumnInfo(name = "resource_id")
    @SerializedName("id")
    private var mId: Int = 0

    @ColumnInfo(name = "name")
    @SerializedName("name")
    private var mName: String? = null

    @ColumnInfo(name = "parent")
    @SerializedName("parent")
    private var mParent: ParentBean? = null

    fun getId(): Int {
        return mId
    }

    fun getName(): String? {
        return mName
    }

    fun getParent(): ParentBean? {
        return mParent
    }

    fun setParent(parent: ParentBean) {
        mParent = parent
    }

    fun setId(id: Int) {
        mId = id
    }

    fun setName(name: String) {
        mName = name
    }

在这里您可以找到我的ParentBean文件

class ParentBean {

    @SerializedName("id")
    private var mId: Int = 0

    fun getId(): Int? {
        return mId
    }

}

我为列表找到了一些解决方案,但没有找到子对象。

感谢您的时间和帮助。

有我以下错误:

Cannot figure out how to save this field into database. You can consider adding a type converter for it.

2 个答案:

答案 0 :(得分:2)

Room在SQLite数据库之上工作,当您将类注释为@Entity时,您正在创建一个表,该表的列是根据类的属性定义的,因此您不能直接存储自定义类型像ParentBean一样,您需要将mParent属性注释为@Embedded

@Entity(tableName = "resources")
class CategoryBean constructor(
    @PrimaryKey
    @ColumnInfo(name = "resource_id")
    @SerializedName("id")
    var mId: Int,
    @ColumnInfo(name = "name")
    @SerializedName("name")
    var mName: String?,
    @SerializedName("parent")
    @Embedded
    var mParent: ParentBean?
)

然后,您在ParentBean中为属性定义列名:

data class ParentBean constructor(@SerializedName("id") @ColumnInfo(name = "parent_id")var mId: Int)

resources表将包含以下列:resource_idnameparent_id

来源:https://developer.android.com/training/data-storage/room/defining-data

注意:您无需在Kotlin中手动定义getter和setter。

答案 1 :(得分:0)

您的问题是您的JSON数据无效。

"resources": [{
  "id": 441988,
  "name": "TVA",
  "parent": {
    "id": 159
  },            //This Line has a comma without another field following it
},
{
  "id": 441900,
  "name": "Marketing",
  "parent": {
    "id": 166
  },           //This Line has a comma without another field following it
}]

另外,整个内容还应该由另一组花括号包围(但我认为由于复制粘贴而被忽略了)。

以下站点是测试您的JSON数据和POJO的一个很好的工具:http://www.jsonschema2pojo.org

希望这会有所帮助:)