SpringBoot开发中查询时间序列timestamp乱码的问题

在做查询功能的时候,数据库MySQL中有时间序列字段,于是我在MySQL中把它定义成了timestamp类型
在这里插入图片描述
但是我使用Mybatis-plus自己生成po类时,它定义的却是java.time.LocalDateTime类型,我用jackson进行全局时间格式配置,他也会产生乱码。

spring:
	  jackson:
    	date-format: yyyy-MM-dd HH:mm:ss.SSS
    "creationDate": "2023-0318 14:54:36",
    "lastUpdatedBy": "PHR",
    "lastUpdatedDate": null

后面查了资料才发现:
Mybatis-Plus 默认情况下会将数据库中 timestamp 类型的字段映射为 Java 对象中的 LocalDateTime 类型。这也是符合 Java 8 及其以上版本的 java.time 标准库中关于日期时间的最佳实践。

如果你不想使用 LocalDateTime,可以通过配置 Mybatis-Plus 的全局配置来修改映射规则,例如将 timestamp 映射为 Date 类型:

mybatis-plus:
  configuration:
    # 全局配置
    global-config:
      # 配置映射策略为 FieldStrategy.NOT_NULL,即非空字段参与 SQL 语句的生成
      db-config:
        id-type: auto
        logic-delete-value: 1
        logic-not-delete-value: 0
        field-strategy: not_null
        table-prefix: t_
        # 配置映射策略,将 timestamp 映射为 Date 类型
        # 其他类型映射可以参考 https://baomidou.com/guide/types.html
        map-underscore-to-camel-case: true
        date-format: yyyy-MM-dd HH:mm:ss
        db-column-underline: true
        db-type: mysql
        db-encrypt-password: false
        db-decimal-scale: 2
        db-rounding-mode: HALF_UP
        entity-map: date:java.util.Date

我最后还是把po类的时间变量修改成了java.sql.Timestamp类型,然后在jackson时间配置上后面加多了个.SSS

  jackson:
    date-format: yyyy-MM-dd HH:mm:ss.SSS

完美解决!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值