开发者社区 > 云原生 > 中间件 > 正文

Seata这问题什么原因?

Seata这问题什么原因?
Field not equals, name in_date, old value 2018-01-01T00:00, new value 2018-01-01 00:00:00.0

展开
收起
青城山下庄文杰 2023-08-11 17:20:39 76 0
1 条回答
写回答
取消 提交回答
  • 这个问题是由于 Spring Data JPA 在插入一条记录时,会将字符串类型的日期转换成 UTC 时区的时间戳。如果您使用的是非 UTC 时区,那么在查询这条记录时,就会出现 Field not equals 的错误。

    要解决这个问题,您可以使用 Spring Data JPA 的 @Convert 注解,将字符串类型的日期转换成您想要的时区。例如,您可以使用以下代码来将字符串类型的日期转换成 GMT+8 时区的时间戳:

    @Convert(converter = StringToDateConverter.class)
    @Column(nullable = false)
    private Date inDate;

    public static class StringToDateConverter implements AttributeConverter {

    @Override
    public Date convertToDatabaseColumn(String date) {
        return new Date(date.getTime());
    }
    
    @Override
    public String convertToEntityAttribute(Date date) {
        return new SimpleDateFormat("yyyy-MM-dd").format(date);
    }
    

    }

    2023-09-26 10:43:41
    赞同 展开评论 打赏
问答地址:

为企业提供高效、稳定、易扩展的中间件产品。

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载