关于mysql时间超过2038年时间戳查询数据问题

问题复现:

有一个联表方案需要对接搜索组,根据活动的结束时间来查询数据,由于搜索组针对日期查询只能传long类型时间戳来比较,某一个长期活动数据明明在时间范围内,但是一直查询不出来,

问题分析:

后来查询数据分析该活动结束时间是2099年,因为是长期活动,所以设置结束时间比较晚。搜索组在构建的时候结束时间的时间戳变成0,发现用了unix_timestamp这个函数,由于timestamp字段最大字节长度是4,只能支持到2038年,只要超过这个时间,就会变成0

解决方案:

怎么解决传的参数类型是long来比较时间的大小呢,时间戳会有2038年问题,后来想到通过时间字符串拼接的方式来比较大小。

mysq

select DATE_FORMAT('2099-01-01 00:00:00', '%Y%m%d%H%i%s');

关于timestamp 和 datetime 这2和字段类型的解释

Mysql的timestamp(时间戳)详解以及2038问题的解决方案_51CTO博客_mysql timestamp 2038

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值