当我使用 realm.where(Model.class) 它返回 RealmResults 并且列表项的字段为空。如何将查询集转换为可读的 ArrayList 或迭代 RealmResults 以从 DB 中的对象获取实际数据?
最佳答案
Realm 中的所有获取都是惰性的,并且永远不会复制数据。所以如果你想从 RealmResults 获取当前数据,你必须调用 realm.copyFromRealm(results)。
public List<Model> getModelList() {
List<Model> list = new ArrayList<>();
Realm realm;
try {
realm = Realm.getDefaultInstance();
RealmResults<Model> results = realm
.where(Model.class)
.findAll();
list.addAll(realm.copyFromRealm(results));
} finally {
if (realm != null) {
realm.close();
}
}
return list;
}
关于java - 如何将 RealmResults<Model> 转换为 ArrayList<Model>?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37250987/