【问题标题】:Enforce multiple constraints in embedded entities with hibernate-search使用 hibernate-search 在嵌入式实体中实施多个约束
【发布时间】: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


    【解决方案1】:

    目前,使用默认索引的 Hibernate Search 无法解决此用例。问题在于 Hibernate Search 将所有要索引的数据(包括通过 @IndexedEmbedded 注释的关联)扁平化为单个 Lucene Document。在这种情况下,特别是失去了由单个 Communication 实例给出的“分组”。如果您有一个具有您感兴趣的类型的 Communication 实例和另一个具有您感兴趣的值的实例,那么您将在您的情况下获得匹配。

    作为一种解决方法,您可以为Communication 实例提供一个自定义类桥,它以某种方式连接您感兴趣的值。然后您将尝试编写一个针对此自定义字段的查询。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-11-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-03-29
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多