首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何防止Mysql Connector/J转换日期和时区?

如何防止Mysql Connector/J转换日期和时区?
EN

Stack Overflow用户
提问于 2020-01-22 20:53:27
回答 2查看 518关注 0票数 2

我正在使用以下DSN连接到mysql服务器:jdbc:mysql://localhost/my_database?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC

我遇到的问题是,java.sql.Date实例正在将时区从本地时区转换为UTC。我的应用程序将日期视为时区不可知,这导致了一些问题。

例如,我在IST (UTC+05:30),当我在代码中设置一些日期字段为'2020-01-22‘时,它会被作为'2020-01-21’发送到服务器。我已经从mysql通用日志中验证了这一点。

我已经尝试了useLegacyDatetimeCodeuseTimezonenoTimezoneConversionForDateType的一些组合,但到目前为止,我无法让mysql驱动程序跳过日期字段的转换。

如何让mysql驱动程序跳过日期和时间字段的转换?

我已经尝试过连接器/J驱动程序mysql:mysql-connector-java:<version>的版本6和版本8。另外,我使用JOOQ并使用一个简单的转换器在LocalDatejava.sql.Date之间进行转换。

EN

回答 2

Stack Overflow用户

发布于 2020-01-22 21:20:46

如果你真的想要一个“时区不可知”的日期,你必须在Java语言中使用LocalDate。LocalDate很好地映射到MySQL的DATE类型。

https://thoughts-on-java.org/hibernate-5-date-and-time/

完全不涉及时区。

票数 0
EN

Stack Overflow用户

发布于 2020-01-27 23:07:58

我自己也有同样的问题,现在我用这个转换器解决了它:

代码语言:javascript
运行
复制
public final class DateConverter implements Converter<Date, LocalDate> {
    @Override
    public final LocalDate from(final Date value) {
        if(null == value) {
            return null;
        } else {
            return value.toLocalDate();
        }
    }

    @Override
    public final Date to(final LocalDate value) {
        if(null == value) {
            return null;
        } else {
            return new Date(value.atStartOfDay(ZoneOffset.UTC).toInstant().toEpochMilli());
        }
    }

    @Override
    public final Class<Date> fromType() {
        return Date.class;
    }

    @Override
    public final Class<LocalDate> toType() {
        return LocalDate.class;
    }
}

我必须承认,如果这个转换器与不同的时区一起使用,我还没有考虑到行为。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59860215

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档