Elasticsearch 条件字段为 date 类型时注意事项

背景

好一阵儿没有写 Elasticsearch 检索代码了,本周弄了一下,又回忆起一些坑点,记录一下。第一个就是 Elasticsearch 的字段类型,date 类型的字段设置查询条件时,参数值设置时,字符串和时间戳两种形式查询结果有差异,温故一下。

Elasticsearch 针对 date 类型字段设置查询条件

对一个索引中的 date 类型字段设置 RangeQuery 条件,查询 2025-12-21 至 22 日之间的数据,时间格式的字符串和时间戳之间的转化关系如下:

当传入时间戳时,查询结果总数为 8871:

当传入与条件字段 format 一致的时间字符串时,统计结果是8676:

问题分析

二者相差几十条,获取查询结果比对,发现传入时间戳时,结果中有不符合条件的数据。

根源是 Elasticsearch 存储 date 类型的值时,使用的 UTC 时间戳,而我们传入参数使用北京时间,直接查询数据晚了 8小时,调整时间戳范围 +8 小时后,两种统计结果就一致了:

结论:如果使用时间戳参数,必须注意时区,检索条件需要加8小时。

Java 解析特殊时间

解析一个不常见的时间字符串 Dec 24 14:07:35 2025,正确的解析方法如下,而且别想设置 Locale.ENGLISH 属性。

bash 复制代码
String dateString = "Dec 24 14:07:35 2025";
SimpleDateFormat sdf = new SimpleDateFormat("MMM dd HH:mm:ss yyyy", Locale.ENGLISH);
try {
    Date date = sdf.parse(dateString);
    System.out.println("解析后的日期: " + date);
} catch (ParseException e) {
    e.printStackTrace();
}
相关推荐
JZC_xiaozhong2 小时前
跨系统审批自动化怎么做?从采购到销售合同的完整方案
大数据·运维·自动化·流程自动化·数据集成与应用集成·业务流程管理·异构数据集成
2601_956139422 小时前
政府事业机构品牌策划公司哪家专业
大数据·人工智能·python
狮子座明仔2 小时前
ThinkTwice: 让模型学会“做完题再检查一遍“,推理+自纠错联合训练只加3%开销
大数据·人工智能·深度学习
ykjhr_3d3 小时前
数字工具AI智能学伴,助力教育数字化转型
大数据·人工智能·ai·ai人工智能·华锐视点·华锐云空间
Gent_倪3 小时前
Hadoop生态组件介绍
大数据·hadoop
动恰客流管家3 小时前
动恰3DV3丨客流统计系统:旺季人手不够淡季闲人太多?客流统计帮你科学优化人力成本
大数据·运维·人工智能·3d
瑞华丽PLM3 小时前
传统研发协同低效痛点待解,PLM 系统数字化选型助力研发效率提升与转型
大数据·plm·国产plm·瑞华丽plm·瑞华丽
乐迪信息4 小时前
乐迪信息:实时预警,秒级响应:船舶AI异常行为检测算法
大数据·人工智能·算法·安全·目标跟踪
红色星际4 小时前
进军具身机器人和Robotaxi的智驾公司
大数据·人工智能·机器人
Bruce_Liuxiaowei4 小时前
《轻量化制播系统技术应用指南(2026版)》解读:县级融媒体的“减负增效“新路径
大数据·人工智能·媒体