mysql时间字符串比较的bug

在尝试比较格式为'2021-09-1610:20'的时间字符串时,使用DATE_FORMAT函数结合'%Y-%m-%d%k:%i'格式化后进行比较出现错误,返回结果为0,不符合预期。问题在于错误的比较方式。通过使用TIMESTAMPDIFF函数转换为分钟比较解决了问题,得到正确结果。
摘要由CSDN通过智能技术生成

记录一个bug:

目的:想要比较两个格式为 '2021-09-16 10:20'    的时间字符串的大小

方案:

因为之前比较格式为 '2021-09-16'    的时间字符串大小的时候使用的方法是:

SELECT DATE_FORMAT('2021-09-16 09:58:00','%Y-%m-%d') <=  '2021-09-16'	

结果为:

可见是正确的

所以比较格式为 '2021-09-16 10:20'    的时间字符串的大小时,我这样写了(注意,有坑)

SELECT DATE_FORMAT('2021-09-16 09:58:00','%Y-%m-%d %k:%i') <=  '2021-09-16 10:20'	

结果为:

 !!!为什么???

显而易见这不是我想要的结果(我现在也没明白为什么会是0,有知道的大佬欢迎留言指导一下!~感谢)

后来是这样解决的:

SELECT TIMESTAMPDIFF(MINUTE, DATE_FORMAT('2021-09-16 09:58:00','%Y-%m-%d %k:%i'), '2021-09-16 10:20') >= 0

结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值