首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过Spring data ElasticSearch repo保存到elasticsearch后,LocalTime(00:01:002)变为(24:00:02)

Spring Data Elasticsearch 是 Spring 框架的一个模块,提供了方便的集成和操作 Elasticsearch 的能力。在使用 Spring Data Elasticsearch 的过程中,遇到 LocalTime 类型的数据保存到 Elasticsearch 后,出现了从 "00:01:002" 变为 "24:00:02" 的情况。

这个问题的原因是 Elasticsearch 在处理时间类型字段时,会将 LocalTime 类型的数据默认当作 UTC 时间来处理。而 "00:01:002" 在 UTC 时间中等同于 "24:00:02"。

要解决这个问题,我们可以通过自定义序列化和反序列化器来处理 LocalTime 类型的数据。下面是具体的解决步骤:

  1. 创建一个实现 org.springframework.core.convert.converter.Converter 接口的自定义转换器,用于将 LocalTime 类型的数据转换为 Elasticsearch 中的时间格式。
代码语言:txt
复制
import org.springframework.core.convert.converter.Converter;

import java.time.LocalTime;
import java.time.format.DateTimeFormatter;

public class LocalTimeToStringConverter implements Converter<LocalTime, String> {

    private static final DateTimeFormatter FORMATTER = DateTimeFormatter.ofPattern("HH:mm:ss.SSS");

    @Override
    public String convert(LocalTime source) {
        return source.format(FORMATTER);
    }
}
  1. 创建一个实现 org.springframework.core.convert.converter.Converter 接口的自定义转换器,用于将 Elasticsearch 中的时间格式转换为 LocalTime 类型的数据。
代码语言:txt
复制
import org.springframework.core.convert.converter.Converter;

import java.time.LocalTime;
import java.time.format.DateTimeFormatter;

public class StringToLocalTimeConverter implements Converter<String, LocalTime> {

    private static final DateTimeFormatter FORMATTER = DateTimeFormatter.ofPattern("HH:mm:ss.SSS");

    @Override
    public LocalTime convert(String source) {
        return LocalTime.parse(source, FORMATTER);
    }
}
  1. 在 Spring Boot 的配置文件中,配置自定义转换器。
代码语言:txt
复制
spring:
  elasticsearch:
    rest:
      client:
        converters:
          - com.example.converter.LocalTimeToStringConverter
          - com.example.converter.StringToLocalTimeConverter

通过以上步骤,就可以解决 LocalTime 类型在保存到 Elasticsearch 后的时间格式变化问题。

关于 Elasticsearch 的更多信息,您可以参考腾讯云提供的 Elasticsearch 产品介绍

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

没有搜到相关的视频

领券