【发布时间】:2016-01-25 13:03:42
【问题描述】:
我有一个关于在使用 hibernate-search 执行查询时强制执行多个约束的可能性的问题。
@Indexed
public class Contact{
//ommited fields
@IndexEmbedded
private List<Communication> communications;
//setters - getters
}
和相关的类
@Indexed
public class Communication{
@Field(analyze = Analyze.YES, store = Store.YES)
private String value;
@Field(analyze = Analyze.YES, store = Store.YES)
private CommunicationType communicationType;
@Field(analyze = Analyze.YES, store = Store.YES)
private CommunicationUsage communicationUsage;
}
枚举
public static enum CommunicationUsage {
PRIVATE,
PROFESSIONNAL
}
public static enum CommunicationType{
PHONE,
EMAIL
}
我需要完成的示例查询如下:
查找通信类型为“PHONE”且 CommunicationUsage 为“PRIVATE”且通信类的字段值包含字符串 999 的所有联系人
public List<Contact> search(){
FullTextEntityManager fullTextEntityManager =
Search.getFullTextEntityManager(em);
QueryBuilder qb = fullTextEntityManager.getSearchFactory()
.buildQueryBuilder().forEntity(Contact.class).get();
org.apache.lucene.search.Query luceneQuery =
qb.bool() .must(qb.keyword().wildcard().onField("communications.value").matching("*99999*").createQuery()) .must(qb.keyword().onField("communications.type").ignoreFieldBridge().matching("phone").createQuery()) .must(qb.keyword().onField("communications.usage").ignoreFieldBridge().matching("private").createQuery())
.createQuery();
org.hibernate.search.jpa.FullTextQuery jpaQuery =
fullTextEntityManager.createFullTextQuery(luceneQuery, Contact.class);
List result = jpaQuery.getResultList();
}
但是,我收到的联系人的电话号码与所提供的电话号码相匹配,但用于不同的通信类型和用途(例如电话和专业)
那么这种类型的查询是否可以通过hibernate-search来完成?
【问题讨论】:
标签: java hibernate hibernate-search