首页  >  文章  >  如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜索索引实体的所有字段

如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜索索引实体的所有字段

PHPz
PHPz转载
2024-02-11 17:15:111141浏览

php小编百草为大家介绍一种使用Hibernate Search 6在Elasticsearch中搜索索引实体的所有字段的方法。Hibernate Search 6是一个强大的全文搜索引擎,可以与Elasticsearch无缝集成。通过配置和使用Hibernate Search 6,您可以轻松地将实体的所有字段都索引到Elasticsearch中,并实现高效的全文搜索功能。本文将为您详细介绍如何配置和使用Hibernate Search 6来实现这一目标。跟随本文的步骤,您将能够快速搭建一个功能强大的全文搜索引擎,提升您的应用程序的搜索功能。

问题内容

我有以下方法,使用 hibernate search api 在 elasticsearch 中进行搜索。我将 querystring 值传递为“addresses.address_key:123”,该值在 fields(addresses.address_key) 中提到的在addresses.address_key 中进行搜索。

如何使此方法接受查询字符串中的任何输入,例如:first_name:john 并使其在所有 fulltextfields 中搜索。

elasticsearch 版本:8.10 hibernatesearch版本:6.2.2

public page<employee> searchemployee(string querystring) {
       try {
            searchsession searchsession = search.session(entitymanager);

            searchresult<employee> searchresult = searchsession.search(employee.class)
                    .extension(elasticsearchextension.get())
                    .where(f -> f.simplequerystring().fields("addresses.address_key").matching(querystring))
                    .fetch(math.tointexact(page.getoffset()), page.getpagesize());

            page<employee> pageresult = new pageimpl<>(searchresult.hits(), page, searchresult.total().hitcount());
            return pageresult;
        } catch (searchexception pe) {
           throw pe;
        }
}

已索引的实体类:

@Indexed(index = "employee")
public class Employee {

  @FullTextField(name = "employee_key")
  private String employeeKey;

  @FullTextField(name = "first_name")
  private String firstName;
    
  @IndexedEmbedded(includeEmbeddedObjectId = true, includeDepth = 2)
  private Address addresses;
}

public class Address {
    
  @FullTextField(name = "address_key")
  private String addressKey;

  @FullTextField(name = "street_name")
  private String streetName;

}

解决方法

您可以定义谓词时明确定位多个字段

searchresult<employee> searchresult = searchsession.search(employee.class)
        .where(f -> f.simplequerystring()
                .fields("employee_key", "first_name", "addresses.address_key")
                .matching(querystring))
        .fetch(math.tointexact(page.getoffset()), page.getpagesize());

目前无法选择仅定位“所有文本字段”;请参阅 https://www.php.cn/link/0b36451530d9491114523d4b66253837

此外,需要明确的是,简单查询字符串语法不支持显式引用查询字符串中的字段。

在此示例中:

f.simplequerystring().fields("addresses.address_key")
        .matching("addresses.address_key:123")

...搜索字符串中的“addresses.address_key:”前缀(“addresses.address_key:123”)没有特定含义,只会被解释为在文档中找到的术语。

你不妨这样写:

f.simplequerystring().fields("addresses.address_key")
        .matching("addresses.address_key 123")

但实际上,我认为你想要的是这样的:

f.simpleQueryString().fields("addresses.address_key")
        .matching("123")

以上是如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜索索引实体的所有字段的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除