如何使用嵌套属性对 RealmList 对象进行排序



我已经开始使用 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来设置放置结果的列表视图

希望这有帮助。

最新更新