在房间数据库中插入用户时显示错误

时间:2019-07-30 09:57:43

标签: java android android-room

我正在制作一个应用程序,其中我将Room用作数据库缓存,并使用Retrofit2从服务器中获取数据并将其保存在Room数据库中,但是从服务器获取数据后无法将其插入Room数据库中。

这是一个例外,它显示: enter image description here

这是我下面的pojo课:

@Entity(tableName = "Users")
public class User {

@NonNull
@PrimaryKey
@SerializedName("_id")
private String _id;

@ColumnInfo(name = "name")
@SerializedName("name")
@Expose
private String name;

@ColumnInfo(name = "age")
@SerializedName("age")
@Expose
private String age;

public User(){}

public User(@NonNull String _id,String name, String age) {
    this._id = _id;
    this.name = name;
    this.age = age;
}

@NonNull
public String get_id() {
    return _id;
}

public void set_id(@NonNull String _id) {
    this._id = _id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public String getAge() {
    return age;
}

public void setAge(String age) {
    this.age = age;
}
}

JSON响应

[
{
    "id": "5cf68fe7b439470017236249",
    "name": "Rhea",
    "age": "2"
},
{
    "id": "5d09006696a8470cbc7c34a2",
    "name": "Don",
    "age": "10"
},
{
    "id": "5d092d9858af5d22a80858bf",
    "name": "Roman",
    "age": "30"
},
{
    "id": "5d09e9976f3bad18b8fa54a0",
    "name": "Roman",
    "age": "30"
},
{
    "id": "5d09ea2ac127bd07b4b64f6f",
    "name": "Roman",
    "age": "30"
}
]

请让我知道发生了什么错误。任何帮助将不胜感激。

3 个答案:

答案 0 :(得分:3)

chnage 

@NonNull
@PrimaryKey
@SerializedName("_id") // key does not match with response key
private String _id;


to 


@NonNull
@PrimaryKey
@SerializedName("id")
private String _id;

答案 1 :(得分:2)

在模型等待“ _id”时,您似乎在JSON中将id参数命名为“ id”。尝试删除该下划线符号。

答案 2 :(得分:0)

我认为您正在使用Retrofit2从服务器获取数据的一个或多个用户ID为空,因此您不能将其插入本地数据库