我正在尝试同时查询包含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;谓词,但我认为它只能与一个值进行比较。
有没有这样做?
答案 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);