ElasticSearch 按 _source 字段搜索
ElasticSearch search by _source fields
我需要实现一个搜索引擎。就像 google / yahoo search,在搜索组件中,如果输入任何键,它应该找到匹配项并显示。为此,我创建了 Spring 与弹性搜索集成的引导项目。
我使用 logstash 在弹性搜索中为我的 Oracle 数据库创建了索引。通过使用下面的代码,我能够根据弹性搜索索引 ID 获取记录。
private final String INDEX = "bookdata";
private final String TYPE = "books";
public Map<String, Object> getBookById(String id){
GetRequest getRequest = new GetRequest(INDEX, TYPE, id);
GetResponse getResponse = null;
try {
getResponse = restHighLevelClient.get(getRequest);
} catch (java.io.IOException e){
e.getLocalizedMessage();
}
Map<String, Object> sourceAsMap = getResponse.getSourceAsMap();
return sourceAsMap;
}
以上代码运行良好,能够根据 ID
获取图书。但我必须知道作者或书名。
请在 Kibana 的 Elastic 搜索中找到我的索引文档
{
"took": 34,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"skipped": 0,
"failed": 0
},
"hits": {
"total": 3,
"max_score": 1,
"hits": [
{
"_index": "bookdata",
"_type": "books",
"_id": "72c58f1a-7bfe-41be-a7f4-ee0aca3f4cf4", //able to search by ID
"_score": 1,
"_source": {
"id": "72c58f1a-7bfe-41be-a7f4-ee0aca3f4cf4",
"title": "Java Always", // want to search by Title
"author": "JournalDev", // or want to search by author
"price": 99.1
}
}
}
不是很清楚,怎样才能用作者或书名搜索。
您需要使用 search API 而不是 Get API。
// create the search request
SearchRequest searchRequest = new SearchRequest(INDEX);
searchRequest.types(TYPE);
// create the match query on the author field
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
MatchQueryBuilder matchQueryBuilder = new MatchQueryBuilder("author", "JournalDev");
searchSourceBuilder.query(matchQueryBuilder);
searchRequest.source(searchSourceBuilder);
// send the request
SearchResponse searchResponse = restHighLevelClient.search(searchRequest);
// read the response
SearchHit[] searchHits = searchResponse.getHits().getHits();
for (SearchHit hit : searchHits) {
// get each hit as a Map
Map<String, Object> sourceAsMap = hit.getSourceAsMap();
String documentTitle = (String) sourceAsMap.get("title");
...
}
我需要实现一个搜索引擎。就像 google / yahoo search,在搜索组件中,如果输入任何键,它应该找到匹配项并显示。为此,我创建了 Spring 与弹性搜索集成的引导项目。
我使用 logstash 在弹性搜索中为我的 Oracle 数据库创建了索引。通过使用下面的代码,我能够根据弹性搜索索引 ID 获取记录。
private final String INDEX = "bookdata";
private final String TYPE = "books";
public Map<String, Object> getBookById(String id){
GetRequest getRequest = new GetRequest(INDEX, TYPE, id);
GetResponse getResponse = null;
try {
getResponse = restHighLevelClient.get(getRequest);
} catch (java.io.IOException e){
e.getLocalizedMessage();
}
Map<String, Object> sourceAsMap = getResponse.getSourceAsMap();
return sourceAsMap;
}
以上代码运行良好,能够根据 ID
获取图书。但我必须知道作者或书名。
请在 Kibana 的 Elastic 搜索中找到我的索引文档
{
"took": 34,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"skipped": 0,
"failed": 0
},
"hits": {
"total": 3,
"max_score": 1,
"hits": [
{
"_index": "bookdata",
"_type": "books",
"_id": "72c58f1a-7bfe-41be-a7f4-ee0aca3f4cf4", //able to search by ID
"_score": 1,
"_source": {
"id": "72c58f1a-7bfe-41be-a7f4-ee0aca3f4cf4",
"title": "Java Always", // want to search by Title
"author": "JournalDev", // or want to search by author
"price": 99.1
}
}
}
不是很清楚,怎样才能用作者或书名搜索。
您需要使用 search API 而不是 Get API。
// create the search request
SearchRequest searchRequest = new SearchRequest(INDEX);
searchRequest.types(TYPE);
// create the match query on the author field
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
MatchQueryBuilder matchQueryBuilder = new MatchQueryBuilder("author", "JournalDev");
searchSourceBuilder.query(matchQueryBuilder);
searchRequest.source(searchSourceBuilder);
// send the request
SearchResponse searchResponse = restHighLevelClient.search(searchRequest);
// read the response
SearchHit[] searchHits = searchResponse.getHits().getHits();
for (SearchHit hit : searchHits) {
// get each hit as a Map
Map<String, Object> sourceAsMap = hit.getSourceAsMap();
String documentTitle = (String) sourceAsMap.get("title");
...
}