时间字符串比较问题

问题背景

在开发过程中我们经常会保存字符串形式的排序,比如”2024-08-31 10:51:54“,或者”2024-08-31“,又或者”10:51:54“,一般我们在使用框架的比较方法时都会自动匹配比对,比如stream.sort,lambdaQuery().orderby(),都是可以成功排序的。

遇到问题

今天遇到一个问题,在比较"9:30"和”10:30“这一类的时间字符串时,排序竟然失效了,根据查阅资料,原因是因为框架在进行排序时候,会根据字符串的数据格式去进行匹配,比如YYYY-MM-DD HH:mm:ss,通过实际运行发现,数据格式一致时,可以正确比较时间大小。如果时间格式YYYY-MM-DD 与YYYY-MM-DD HH:mm:ss 对比时,例:2022-03-31 与 2023-03-31 11:50:35 比较的结果为大于0,因此,使用String进行时间数据的对比时,最好先统一格式。

解决问题

所以看到这里大概就知道问题了,要保持时间类型的格式,所以将9:30一类的数据改成09:30就可以正常进行排序比较啦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值