我的页面上有一个搜索字段,这个搜索字段应该搜索多个indice。 我可以毫无问题地搜索一个indice,就像spring-data-elasticsearch的文档中所描述的那样。
但如果我搜索,作为" Foo"的例子,我希望按照相关性排序以下列表:
{ title: "Foo" } -> Entity: Sample
{ name: "FooTest" } -> Entity: Test
{ title: "FooSample2" } -> Entity: Sample
// ...and so on
// The entities are not part of the same parent. So, they are complete different.
为此,我无法在文档中找到任何可以帮助我的内容。
任何人都可以帮忙吗?
修改
final SearchQuery searchQuery = new NativeSearchQueryBuilder().withQuery(QueryBuilders.matchAllQuery())
.withIndices("game-index", "lets-play-index", "video-index", "genre-index", "platform-index", "user-index")
.withPageable(new PageRequest(0, 10))
.build();
// when
final Page<SearchResult> sampleEntities = elasticsearchTemplate.queryForPage(searchQuery, SearchResult.class, new SearchResultMapper() {
@Override
public <T> FacetedPage<T> mapResults(
final SearchResponse response,
final Class<T> clazz,
final Pageable pageable) {
LoggerUtil.get(this.getClass())
.debug(response.toString());
LoggerUtil.get(this.getClass())
.debug(response.getHits()
.toString());
LoggerUtil.get(this.getClass())
.debug("TotalHits: " + response.getHits()
.totalHits());
final long totalHits = response.getHits()
.totalHits();
final List<T> results = new ArrayList<T>();
for (final SearchHit hit : response.getHits()) {
LoggerUtil.get(this.getClass())
.debug(hit.sourceAsString());
if (hit != null) {
final T result = null;
/*
* if (!Strings.isNullOrEmpty(hit.sourceAsString()))
* { result = mapEntity(hit.sourceAsString(),
* clazz); } else { result =
* mapEntity(hit.getFields() .values(), clazz); }
*/
// setPersistentEntityId(result, hit.getId(),
// clazz);
results.add(result);
}
}
final List<FacetResult> facets = new ArrayList<FacetResult>();
if (response.getFacets() != null) {
for (final Facet facet : response.getFacets()) {
final FacetResult facetResult = DefaultFacetMapper.parse(facet);
if (facetResult != null) {
facets.add(facetResult);
}
}
}
return new FacetedPageImpl<T>(results, pageable, totalHits, facets);
}
});
SearchResultMapper内部的响应如下:
{
"took" : 5,
"timed_out" : false,
"_shards" : {
"total" : 30,
"successful" : 30,
"failed" : 0
},
"hits" : {
"total" : 0,
"max_score" : null,
"hits" : [ ]
}
}
如果我用这个进行简单的搜索:
final Class<?> clazz = Class.forName(className);
final SearchQuery searchQuery = new NativeSearchQueryBuilder().withQuery(getQueryBuilderForQuery(query))
.build();
final List<?> results = elasticsearchTemplate.queryForList(searchQuery, clazz);
它有效,我得到很多结果。这意味着我的索引正在运行。
我绝对不知道我能做些什么。非常感谢。答案 0 :(得分:2)
抱歉这已经支持了
尝试以下代码,它应该正常工作......
但是下面的代码是针对您在Entity和elasticsearch文档中具有相同结构的地方
@Test
public void shouldTestResultsAcrossMultipleIndices() {
// given
String documentId1 = randomNumeric(5);
SampleEntity sampleEntity1 = new SampleEntityBuilder(documentId1).message("some message")
.version(System.currentTimeMillis()).build();
IndexQuery indexQuery1 = new IndexQueryBuilder().withId(sampleEntity1.getId())
.withIndexName("test-index-1")
.withObject(sampleEntity1)
.build();
String documentId2 = randomNumeric(5);
SampleEntity sampleEntity2 = new SampleEntityBuilder(documentId2).message("some test message")
.version(System.currentTimeMillis()).build();
IndexQuery indexQuery2 = new IndexQueryBuilder().withId(sampleEntity2.getId())
.withIndexName("test-index-2")
.withObject(sampleEntity2)
.build();
elasticsearchTemplate.bulkIndex(Arrays.asList(indexQuery1, indexQuery2));
elasticsearchTemplate.refresh("test-index-1", true);
elasticsearchTemplate.refresh("test-index-2", true);
SearchQuery searchQuery = new NativeSearchQueryBuilder()
.withQuery(matchAllQuery())
.withIndices("test-index-1", "test-index-2")
.build();
// when
List<SampleEntity> sampleEntities = elasticsearchTemplate.queryForList(searchQuery, SampleEntity.class);
// then
assertThat(sampleEntities.size(), is(equalTo(2)));
}
如果你在索引中有不同的结构,那么你可以使用elasticsearchTemplate的下面方法
Page<T> queryForPage(SearchQuery query, Class<T> clazz, SearchResultMapper mapper);
仍然困惑?
乐于帮助
: - )