是否可以查询包含字符串值列表的多个字段(Realm Java)

时间:2017-09-28 14:42:54

标签: android realm realm-java

我正在尝试同时查询包含Realm中字符串值列表的多个字段。 让我们说我有以下对象:

public class Article extends RealmObject implements Serializable{
    @PrimaryKey
    @Required
    private String aID = UUID.randomUUID().toString();

    private String title;
    private String description;
    private String authors;
    private RealmList<Tag> tags;
}

我想查询所有文章的标题,描述或标签包含字符串列表。

我知道谓词&#34; &#34;可用于将值列表与字段匹配,如下所示:

realm.where(Article.class)
    .in("title", listOfValues,Case.INSENSITIVE)
    .or()
    .in("description", listOfValues, Case.INSENSITIVE)
    .or()
    .in("tags.tag",listOfValues, Case.INSENSITIVE)
    .findAll();

这只会返回&#34; 匹配&#34;值,但我正在寻找&#34; 包含&#34;值。还有&#34;包含&#34;谓词,但我认为它只能与一个值进行比较。

有没有这样做?

2 个答案:

答案 0 :(得分:2)

解决这个问题的工作是@EpicPandaForce在他的评论中建议,迭代和使用包含。以下是执行此操作的代码:

 RealmResults<Article> newResults;
 RealmQuery<Article> where = r.where(Article.class).beginGroup();
 for (String keyword : keywords) {
     where = where.contains("name", keyword, Case.INSENSITIVE)
             .or()
             .contains("description", keyword, Case.INSENSITIVE)
             .or()
             .equalTo("tags.tag", keyword, Case.INSENSITIVE);
 }

 newResults = where.endGroup().findAll();

答案 1 :(得分:0)

一个简单的答案是直接使用.contains(遗憾的是,在Realm-java文档中没有对此进行解释)。

realm.where(Article.class) 
    .contains("title", listOfValues, Case.INSENSITIVE)
    .or()
    .contains("description", listOfValues, Case.INSENSITIVE)
    .or()
    .contains("tags.tag",listOfValues, Case.INSENSITIVE)
    .findAll();

在Realm-Java代码中,您可以找到2种方法:

public RealmQuery<E> contains(String fieldName, String value);
public RealmQuery<E> contains(String fieldName, String value, Case casing);