Java 实现ES查询

	@Resource
	private RestHighLevelClient restHighLevelClient;

	@SuppressWarnings("unchecked")
	@Override
	public List<T> esSearch(String index, String template, Map<String, Object> map) {
		SearchTemplateRequest request = new SearchTemplateRequest();
		request.setRequest(new SearchRequest(index));
		request.setScriptType(ScriptType.STORED);
		request.setScript(template);
		request.setScriptParams(map);
		List<T> res = new ArrayList<>();
		try {
			SearchTemplateResponse searchResponse = restHighLevelClient.searchTemplate(request, RequestOptions.DEFAULT);
			if(null == searchResponse) {
				return res;
			}
			SearchHits hits = searchResponse.getResponse().getHits();
			res = (List<T>) Arrays.stream(hits.getHits()).map(hit -> {
				return hit.getSourceAsMap();
			}).collect(Collectors.toList());
		} catch (Exception e) {
			log.error("{ES查询异常}----->" + e);
		}
		return res;
	}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 首先,需要在Java项目中引入ElasticsearchJava API依赖: ``` <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>elasticsearch-rest-high-level-client</artifactId> <version>7.12.0</version> </dependency> ``` 2. 创建Elasticsearch客户端连接: ``` RestHighLevelClient client = new RestHighLevelClient( RestClient.builder( new HttpHost("localhost", 9200, "http"))); ``` 3. 创建查询请求: ``` SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.from(pageNumber * pageSize); sourceBuilder.size(pageSize); sourceBuilder.query(QueryBuilders.matchAllQuery()); searchRequest.source(sourceBuilder); ``` 其中,`pageNumber`为要查询的页码,`pageSize`为每页的大小。 4. 执行查询请求: ``` SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); ``` 5. 处理查询结果: ``` SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits) { // 处理查询结果 } ``` 完整代码示例: ``` RestHighLevelClient client = new RestHighLevelClient( RestClient.builder( new HttpHost("localhost", 9200, "http"))); int pageNumber = 1; int pageSize = 10; SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.from(pageNumber * pageSize); sourceBuilder.size(pageSize); sourceBuilder.query(QueryBuilders.matchAllQuery()); searchRequest.source(sourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits) { // 处理查询结果 } client.close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值