我需要你的帮助。 我尝试在不进行反序列化的情况下找到解决方案,但没有发现任何问题。 如果您能帮助我,那就太好了... 所以我有这个以下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.
答案 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_id
,name
,parent_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
希望这会有所帮助:)