elasticsearch 如果按照日期进行筛选

如果你需要按照日期进行筛选,你可以使用 Elasticsearch 的范围查询来实现。以下是一个示例代码,演示如何在 Java 中进行日期范围查询:

复制代码
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestClientBuilder;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.search.SearchHit;

import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

public class ElasticsearchQueryWithDateRange {
   

    public static void main(String[] args) {
   
        // Elasticsearch集群的主机和端口
        String hostname = "your_hostname";
        int port = 9200;

        // 认证信息
        String username = "your_username";
        String password = "your_password";

        // 构建认证
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials(username, password));

        // 构建RestClient
        RestClientBuilder builder = RestClient.builder(new HttpHost(hostname, port))
                .setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider));

        // 构建RestHighLevelClient
        RestHighLevelClient client = new RestHighLevelClient(builder);

        // 构建日期格式化对象
        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");

        // 定义起始日期和结束日期
        Date startDate = ...; // 设置起始日期
        Date endDate = ...;   // 设置结束日期

        // 构建搜索请求
        SearchRequest searchRequest = new SearchRequest("your_index_name");
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();

        // 添加日期范围查询条件
        searchSourceBuilder.query(QueryBuilders.rangeQuery("date_field_name")
                .gte(dateFormat.format(startDate))
                .lt(dateFormat.format(endDate)));

        searchRequest.source(searchSourceBuilder);

        try {
   
            // 执行搜索请求
            SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);

            // 处理搜索结果
            for (SearchHit hit : searchResponse.getHits().getHits()) {
   
                // 读取每个搜索结果的数据
                String documentId = hit.getId();
                String documentSource = hit.getSourceAsString();
                System.out.println("Document ID: " + documentId);
                System.out.println("Document Source: " + documentSource);
            }
        } catch (IOException e) {
   
            e.printStackTrace();
        } finally {
   
            // 关闭客户端连接
            try {
   
                client.close();
            } catch (IOException e) {
   
                e.printStackTrace();
            }
        }
    }
}

在这个示例中,你需要将 date_field_name 替换为你的文档中实际存储日期的字段名称,同时设置合适的起始日期 startDate 和结束日期 endDate。确保日期格式化对象的格式与你的日期字段格式匹配。

这个示例将执行一个范围查询,返回指定日期范围内的文档。

相关推荐
武子康3 小时前
大数据-184 Elasticsearch Doc Values 机制详解:列式存储如何支撑排序/聚合/脚本
大数据·后端·elasticsearch
expect7g3 小时前
Paimon源码解读 -- Compaction-8.专用压缩任务
大数据·后端·flink
良策金宝AI6 小时前
从CAD插件到原生平台:工程AI的演进路径与智能协同新范式
大数据·人工智能
康实训6 小时前
智慧老年实训室建设核心方案
大数据·实训室·养老实训室·实训室建设
min1811234566 小时前
分公司组织架构图在线设计 总部分支管理模板
大数据·人工智能·信息可视化·架构·流程图
周杰伦_Jay6 小时前
【Elasticsearch】核心概念,倒排索引,数据操纵
大数据·elasticsearch·搜索引擎
cai_cai07 小时前
springAlibaba + ollama + es 完成RAG知识库功能
大数据·elasticsearch·搜索引擎
Cx330❀7 小时前
Git 分支管理完全指南:从基础到团队协作
大数据·git·搜索引擎·全文检索
库库茯苓7 小时前
Kibana报错:Unable to retrieve version information from Elasticsearch nodes (解决方法)Window11环境
elasticsearch·kibana
nhdh7 小时前
ELK(elasticsearch-7.6.2,kibana-7-6-2,Logstash-7.6.2)单节点部署
大数据·elk·elasticsearch