java在es中简单获取数据

本文主要介绍如何使用Java客户端在Elasticsearch(ES)中进行数据的简单获取,适用于ES版本的操作。
摘要由CSDN通过智能技术生成

es版本

<!--Es连接-->
<dependency>
     <groupId>org.elasticsearch.client</groupId>
     <artifactId>elasticsearch-rest-high-level-client</artifactId>
     <version>7.1.1</version>
 </dependency>
public List<T> getEsData(T2 t2){
   
	RestHighLevelClient client = EsClient.getConnection();             //获取连接对象, 其方法一般在工具类中
	List<T> resultList = new LinkedList>();		//返回的结果list
	QueryBuilder qBuilder = geBuilder(t2);  	//获取查询的条件
    SearchSourceBuilder sourceBuilder = new SearchSourceBuilder()      //创建 查询 对象
        .size(5000)                                  //返结果size
        .sort(new FieldSortBuilder("timestamp")      //排序
        .order(SortOrder.DESC));                     //正序
    SearchRequest rq = new SearchRequest("esIndex")  //请求 索引库
        .source(sourceBuilder)
要在Java获取Elasticsearch某个字段的数据,你可以使用Elasticsearch的Java客户端库来实现。以下是一个简单的示例代码,演示如何检索指定字段的数据: ```java import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.search.SearchHit; import org.elasticsearch.search.builder.SearchSourceBuilder; public class ElasticsearchExample { public static void main(String[] args) { RestHighLevelClient client = new RestHighLevelClient( RestClient.builder("localhost:9200")); try { SearchRequest searchRequest = new SearchRequest("your_index_name"); SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.query(QueryBuilders.matchAllQuery()); // 可以根据你的查询条件进行设置 sourceBuilder.fetchSource(new String[] {"your_field_name"}, null); // 指定需要返回的字段 searchRequest.source(sourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); SearchHit[] searchHits = searchResponse.getHits().getHits(); for (SearchHit hit : searchHits) { String fieldValue = hit.getSourceAsMap().get("your_field_name").toString(); System.out.println(fieldValue); } } catch (Exception e) { e.printStackTrace(); } finally { try { client.close(); } catch (Exception e) { e.printStackTrace(); } } } } ``` 在上述代码,你需要将`"localhost:9200"`替换为你实际的Elasticsearch主机和端口。`"your_index_name"`是你要检索的索引名称,`"your_field_name"`是你要检索的字段名称。 通过运行上述代码,你将能够获取到Elasticsearch指定字段的数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值