我不能用这个查询代码获得高亮显示的字段,任何想法,我使用的是SDE4.0.0.RC2,我想使用@ query:
@Query("{\n" +
" \"multi_match\": {\n" +
" \"query\": \"?0\",\n" +
" \"fields\": [\n" +
" \"code^2\",\n" +
" \"name\"\n" +
" ],\n" +
" \"analyzer\": \"standard\"\n" +
" }\n" +
"}")
@Highlight(
fields = @HighlightField(
name = "['code','name']"),
parameters = @HighlightParameters(
preTags = "<strong>",
postTags = "</strong>",
fragmentSize = 500,
numberOfFragments = 3
)
)
List<CodeNames> findAllByCodeAndNameOrderByName(String code, Pageable pageable);发布于 2020-05-05 02:28:48
您需要在单独的注释参数中指定每个突出显示字段:
@Query("{\n" +
" \"multi_match\": {\n" +
" \"query\": \"?0\",\n" +
" \"fields\": [\n" +
" \"code^2\",\n" +
" \"name\"\n" +
" ],\n" +
" \"analyzer\": \"standard\"\n" +
" }\n" +
"}")
@Highlight(
fields = {
@HighlightField(name = "code"),
@HighlightField(name = "name")
},
parameters = @HighlightParameters(
preTags = "<strong>",
postTags = "</strong>",
fragmentSize = 500,
numberOfFragments = 3
)
)
List<CodeNames> findAllByCodeAndNameOrderByName(String code, Pageable pageable);编辑:
除此之外,您还必须更改方法的返回类型:
List<SearchHit<CodeNames>> findAllByCodeAndNameOrderByName(String code, Pageable pageable);或者
SearchHits<CodeNames> findAllByCodeAndNameOrderByName(String code, Pageable pageable);若要能够从返回的SearchHit中读取突出显示的值,请参阅https://docs.spring.io/spring-data/elasticsearch/docs/4.0.0.RC2/reference/html/#elasticsearch.operations.searchresulttypes
https://stackoverflow.com/questions/61581529
复制相似问题