问题复现:
有一个联表方案需要对接搜索组,根据活动的结束时间来查询数据,由于搜索组针对日期查询只能传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