resthighlevelclient 查询
时间: 2023-09-11 14:05:19 浏览: 92
Spring-elastic-search-rest-high-level-client.zip
您好!对于使用 Elasticsearch 的 Java 客户端库 RestHighLevelClient 进行查询操作,您可以使用以下示例代码:
```java
import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import java.io.IOException;
public class ElasticsearchQueryExample {
public static void main(String[] args) {
RestHighLevelClient client = new RestHighLevelClient(
RestClient.builder(new HttpHost("localhost", 9200, "http")));
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(QueryBuilders.matchQuery("field", "value"));
SearchRequest searchRequest = new SearchRequest("index_name");
searchRequest.source(sourceBuilder);
try {
SearchResponse searchResponse = client.search(searchRequest);
// 处理搜索结果
} catch (IOException e) {
e.printStackTrace();
}
try {
client.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
上述代码中,我们创建了一个 RestHighLevelClient 对象,并指定 Elasticsearch 节点的主机和端口。然后,我们构建一个 SearchSourceBuilder 对象,设置查询条件(这里使用了 matchQuery 进行示范)。接下来,我们创建一个 SearchRequest 对象,设置索引名称和查询条件。最后,通过调用 client 的 search 方法执行查询,并处理返回的 SearchResponse 结果。
请注意,您需要将 "localhost" 和 9200 替换为您实际的 Elasticsearch 主机和端口,"index_name" 替换为您要查询的索引名称,"field" 替换为您要匹配的字段名称,"value" 替换为您要匹配的字段值。
希望可以帮到您!如果您有更多问题,请随时提问。
阅读全文