首頁 > Java > 如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜尋索引實體的所有字段

如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜尋索引實體的所有字段

PHPz
發布: 2024-02-11 17:15:11
轉載
1232 人瀏覽過

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

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;

        }

}

登入後複製

已索引的實體類別:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

@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;

 

}

登入後複製

解決方法

您可以定義謂詞時明確定位多個欄位

1

2

3

4

5

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

此外,需要明確的是,簡單查詢字串語法不支援明確引用查詢字串中的欄位。

在此範例中:

1

2

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

        .matching("addresses.address_key:123")

登入後複製

...搜尋字串中的「addresses.address_key:」前綴(「addresses.address_key:123」)沒有特定意義,只會被解釋為在文件中找到的術語。

你不妨這樣寫:

1

2

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

        .matching("addresses.address_key 123")

登入後複製

但實際上,我認為你想要的是這樣的:

1

2

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

        .matching("123")

登入後複製

以上是如何使用 hibernateSearch 6 在 ElasticSeacrch 中搜尋索引實體的所有字段的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板