我已经开始使用 Realm 了,我很好奇是否可以按嵌套属性对 RealmList 对象进行排序。
我有一些列表模型对象:
public class ListModel extends RealmObject {
@Required
private String itemName;
...
private RealmList<ItemModel> items;
...
}
项目模型是:
public class ItemModel extends RealmObject {
private TagModel tag;
...
private boolean isBought = false;
@PrimaryKey
private long created;
...
}
标签模型是:
public class TagModel extends RealmObject {
@PrimaryKey
private String tagName;
...
private CategoryModel category;
...
}
和类别模型是:
public class CategoryModel extends RealmObject {
@PrimaryKey
private int categoryType;
...
}
所以,我真正需要的是拥有这样的东西:
RealmResults<ItemModel> sortedItems= realm.where(ListModel.class)
.equalTo("created", created)
.findFirst().getItems().where().findAllSorted("isBought", Sort.ASCENDING, "tag.category.categoryType", Sort.ASCENDING, "tag.tagName", Sort.ASCENDING);
是否有可能以某种方式实现这一目标?目前,据我了解,不可能使用以下结构"tag.category.categoryType"
来满足我的需求。
作为临时解决方案,我正在考虑以下方法:
ListModel listModel = realm.where(ListModel.class)
.equalTo("created", created)
.findFirst();
List<ItemModel> items = listModel.getItems();
Collections.sort(items, new Comparator<ItemModel>() {
@Override
public int compare(ItemModel lhs, ItemModel rhs) {
// here some sorting logic
}
});
但我不确定这是一种正确的方法。
Gonzalo的方法目前看起来不错。但它有点慢,因为访问嵌套项目会导致 I/O。就我而言,30 个项目大约需要 10000 秒。所以我改进它以使用缓存。
Collections.sort(medicineClassList, new Comparator<MedicineClass>() {
Map<String, String> primaryKey2SortKey = new HashMap();
@Override
public int compare(MedicineClass lmo, MedicineClass rmo) {
String lmo_string = pullSortKey(lmo);
String rmo_string = pullSortKey(rmo);
return lmo_string.compareToIgnoreCase(rmo_string);
}
private String pullSortKey(MedicineClass item) {
if (primaryKey2SortKey.containsKey(item.getPrimaryKey())) {
return primaryKey2SortKey.get(item.getPrimaryKey());
}
String sortKey = item.getProduct_request().getProduct().getName();
primaryKey2SortKey.put(item.getPrimaryKey(), sortKey);
return sortKey;
}
});
我有同样的问题,我用同样的方式解决了这个问题,使用 RealmList 上的集合
我的排序需要按字母顺序对嵌套在主对象中的 RealmList 上的列表名称进行排序
//medicineClassList is a RealmList with some RealmObjects
Collections.sort(medicineClassList, new Comparator<MedicineClass>() {
@Override
public int compare(MedicineClass lmo, MedicineClass rmo) {
String lmo_string = lmo.getProduct_request().getProduct().getName();
String rmo_string = rmo.getProduct_request().getProduct().getName();
return lmo_string.compareToIgnoreCase(rmo_string);
}
});
因此,我在自定义适配器中使用medicineClassList
来设置放置结果的列表视图
希望这有帮助。