android – 带List的Realm查询

前端之家收集整理的这篇文章主要介绍了android – 带List的Realm查询前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用领域将我的数据存储在 Android上.很棒的框架!现在我唯一的问题是:

我的数据库中有一个带有国家ID的数组列表字符串.

现在我找回包含与国家关系的饮料.

有没有办法可以像这样进行查询

  1. String [] ids;
  2.  
  3. realm.where(Drinks.class).equalsTo("country.id",ids);

那样的东西?

或者我真的需要进行查询获取所有饮料,然后手动过滤列表?

编辑:

我的课程:

  1. public class Drinks extends RealmObject {
  2. @PrimaryKey
  3. private String id;
  4. private String name;
  5. private Country country;
  6. }
  7.  
  8. public class Country extends RealmObject {
  9. @PrimaryKey
  10. private String id;
  11. private String name;
  12. }

解决方法

你理想的是理论上的链接查询(搜索“country.id”),但是链接查询很慢.此外,您需要将一堆或()谓词连接在一起,我不会冒险使用链接查询.

我建议使用以下内容

  1. public class Drinks extends RealmObject {
  2. @PrimaryKey
  3. private String id;
  4. private String name;
  5. private Country country;
  6. @Index
  7. private String countryId;
  8. }
  9.  
  10. public class Country extends RealmObject {
  11. @PrimaryKey
  12. private String id;
  13. private String name;
  14. }

在类中设置Country时,还将countryId设置为country.getId().

一旦你这样做,你可以构建这样的:

  1. RealmQuery<Drinks> drinkQuery = realm.where(Drinks.class);
  2. int i = 0;
  3. for(String id : ids) {
  4. if(i != 0) {
  5. drinkQuery = drinkQuery.or();
  6. }
  7. drinkQuery = drinkQuery.equalTo("countryId",id);
  8. i++;
  9. }
  10. return drinkQuery.findAll();

猜你在找的Android相关文章