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中文網其他相關文章!