Программное сопоставление со встроенным индексом в Hibernate Search приводит к невозможности найти ошибку поля

Мне нужно выполнить программную настройку полей для индексации с помощью Hibernate Search.

В приведенном ниже сценарии использование indexEmbedded () приводит к ошибке «поле не найдено».

@Entity
public class AT {
    @ManyToOne(fetch = FetchType.EAGER)
    @JoinColumn(name = "ARRM_IDE", nullable = false)
    private A arr;

    private Date dateType;

    (and other fields)
}

@Entity
public class A {

    @Id
    @SequenceGenerator(name = "C_SEQUENCE", sequenceName = "S_ARRM_01")
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "C_SEQUENCE")
    @Column(name = "IDE_ARR")
    private Long id;
}

SearchMapping mapping = new SearchMapping();
mapping.entity(AT.class).indexed()
        .property("dateType", ElementType.FIELD)
        .field()
        .store(Store.YES)
        .property("arr", ElementType.FIELD)
        .indexEmbedded()
        .entity(A.class).indexed()
        .property("id", ElementType.FIELD).documentId().name("arrId")
        .field()
        .store(Store.YES)
        ;

Когда я создаю и сохраняю сущности (я интегрировал Hibernate Search с Elasticsearch), сущности создаются и индексы также создаются в Elasticsearch.

содержимое на Elasticsearch:

      "_index" : "com.....at",
      "_type" : "com.....AT",
      "_id" : "7744",
      "_score" : 1.0,
      "_source" : {
        "dateType" : "2016-06-12T06:08:52.780Z",
        "arr" : {
          "id" : 6352
        }
      }
    } ]

Но когда я пытаюсь выполнить запрос с помощью запроса Hibernate Search Lucene, он терпит неудачу:

FullTextEntityManager fullTextEntityManager =
        org.hibernate.search.jpa.Search.getFullTextEntityManager(em);
QueryBuilder qb = fullTextEntityManager.getSearchFactory()
        .buildQueryBuilder().forEntity(AT.class).get();
org.apache.lucene.search.Query luceneQuery = qb.bool()
        .must(qb
                .range()
                .onField("dateType")
                .from(parseDate(startDate))
                .to(parseDate(endDate)).excludeLimit()
                .createQuery())
        .must(qb
        .keyword()
        .onField("arr")
        .matching(crsArrId).createQuery())
        .createQuery();
Sort sort = null;
if (order == OrderEnum.ASCENDING) {
    sort = new Sort(
            new SortField("dateType", SortField.Type.STRING));
} else {
    sort = new Sort(
            new SortField("dateType", SortField.Type.STRING, true));
}
FullTextQuery jpaQuery = fullTextEntityManager.createFullTextQuery(luceneQuery, AT.class);
jpaQuery.setSort(sort);
jpaQuery.setFirstResult(offset);
jpaQuery.setMaxResults(maxReturnedEvents);

return jpaQuery.getResultList();

Ошибка:

org.hibernate.search.exception.SearchException: Unable to find field arr in com....AT
    at org.hibernate.search.engine.spi.DocumentBuilderIndexedEntity.objectToString(DocumentBuilderIndexedEntity.java:977)
    at org.hibernate.search.query.dsl.impl.FieldContext.objectToString(FieldContext.java:75)
    at org.hibernate.search.query.dsl.impl.ConnectedMultiFieldsTermQueryBuilder.buildSearchTerm(ConnectedMultiFieldsTermQueryBuilder.java:145)
    at org.hibernate.search.query.dsl.impl.ConnectedMultiFieldsTermQueryBuilder.createQuery(ConnectedMultiFieldsTermQueryBuilder.java:105)
    at org.hibernate.search.query.dsl.impl.ConnectedMultiFieldsTermQueryBuilder.createQuery(ConnectedMultiFieldsTermQueryBuilder.java:67)

Спасибо за вашу помощь!


person Priya Gachinamath    schedule 10.06.2016    source источник


Ответы (1)


Вы хотите искать по arr.id, а не по arr.

Просто измените .onField ("arr") на .onField ("arr.id").

person Guillaume Smet    schedule 10.06.2016
comment
Не помогло :( .. теперь выкидывает NPE - person Priya Gachinamath; 10.06.2016
comment
Не могли бы вы быть более конкретными и предоставить трассировку стека? - person Guillaume Smet; 10.06.2016
comment
Спасибо, Гийом - я не знаю, как, но сейчас это работает. - person Priya Gachinamath; 13.06.2016