我正在尝试使用Android中的Realm数据库解析并插入JSON响应。以下是我最终的例外情况:
io.realm.exceptions.RealmException: Could not create JSON array from string
at io.realm.Realm.createOrUpdateAllFromJson(Realm.java:396)
at mobile.login.LoginFragment$1.onResponse(LoginFragment.java:218)
at okhttp3.RealCall$AsyncCall.execute(RealCall.java:133)
at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32) atjava.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
我想解析的JSON:
{
"count": 1,
"statuses": [
{
"id": 0,
"name": "Visible",
"count": 0,
"sort_order": 0
},
{
"id": "1",
"name": "Invisible",
"count": 0,
"sort_order": "1"
}]
}
Count.java Pojo
public class Count extends RealmObject{
@PrimaryKey
private int count;
private RealmList<Statuses> statuses;
public int getCount() {
return count;
}
public void setCount(int count) {
this.count = count;
}
public RealmList<Statuses> getStatuses() {
return statuses;
}
public void setStatuses(RealmList<Statuses> statuses) {
this.statuses = statuses;
}
}
Statuses.java Pojo
public class Statuses extends RealmObject{
@PrimaryKey
@SerializedName("id")
@Expose
private String id;
@SerializedName("name")
@Expose
private String name;
@SerializedName("count")
@Expose
private Integer count;
@SerializedName("sort_order")
@Expose
private String sortOrder;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getCount() {
return count;
}
public void setCount(Integer count) {
this.count = count;
}
public String getSortOrder() {
return sortOrder;
}
public void setSortOrder(String sortOrder) {
this.sortOrder = sortOrder;
}
}
这是我尝试解析和存储JSON的方法:
Realm realm = Realm.getInstance(getContext());
realm.beginTransaction();
realm.createOrUpdateAllFromJson(Order.class, **"JSON STRING HERE"**);
realm.commitTransaction();
如果有人能帮助我解决这个问题,那真的很棒。提前谢谢!
答案 0 :(得分:3)
方法createOrUpdateAllFromJson()
期望json中的根对象为Array
。
您的代码适用于此json:
[{
"count": 1,
"statuses": [
{
"id": 0,
"name": "Visible",
"count": 0,
"sort_order": 0
},
{
"id": "1",
"name": "Invisible",
"count": 0,
"sort_order": "1"
}]
}]
使用createOrUpdateObjectFromJson()
只添加一个对象(感谢@EpicPandaForce)。
以下是createOrUpdateAllFromJson
方法
/**
* Tries to update a list of existing objects identified by their primary key with new JSON data. If an existing
* object could not be found in the Realm, a new object will be created. This must happen within a transaction.
*
* @param clazz type of {@link io.realm.RealmObject} to create or update. It must have a primary key defined.
* @param json string with an array of JSON objects.
* @throws java.lang.IllegalArgumentException if trying to update a class without a
* {@link io.realm.annotations.PrimaryKey}.
* @throws RealmException if unable to create a JSON array from the json string.
* @see #createAllFromJson(Class, String)
*/
public <E extends RealmObject> void createOrUpdateAllFromJson(Class<E> clazz, String json) {
if (clazz == null || json == null || json.length() == 0) {
return;
}
checkHasPrimaryKey(clazz);
JSONArray arr;
try {
arr = new JSONArray(json);
} catch (JSONException e) {
throw new RealmException("Could not create JSON array from string", e);
}
createOrUpdateAllFromJson(clazz, arr);
}