mysql时间计算函数

当前一个业务需求,需要查找创建在三天以前的数据,表中是存了一个创建时间的;这个需求看起来很简单,直接全部查找出来然后用代码根据时间筛选一下就可以了。但这只是适用于数据量不大的情况下,如果数据量大,又要分页的话,还用代码实现的话,很可能会造成内存不足的问题。我认为mysql肯定提供了一些关于时间计算的函数,google一下,果不其然,发现了datediff和timediff这样的函数,

datediff(date1,date2):计算date1减去date2的天数,但是计算规则限定死了,只按日期相减,29号早上减去28号晚上,结果还是为1,如图1;


图1

这跟我们常识不太一样,我们的常识是,现在是早上11点,那么到昨天早上11点,才算是一天,昨天晚上11点到今天早上11点智能算半天。

所以不能用datediff函数,只能用timediff函数;

timediff(time1,time2):计算time1减去time2的时间数,这个减出来的是个time类型,而且还不能直接比较大小,这就很尴尬了。


图2

如图2,相减出来,有一百多个小时的,有几十个小时的,但是如果加入时间相差大于20个小时这个限制条件之后,问题就来了:


图3

如图3,相差一百多个小时的并没有被筛选出来。我猜测这个时间可能用的位运算之类的,具体没有去求证。

所以相减出来的结果是没有办法直接比较大小的,这时候就需要把这个结果转换成可以直接比较大小的秒数,用time_to_second(time1)这个函数,然后直接把限定的时间差也转换成秒数,比如一天=24x3600秒,依此类推,然后就可以直接做筛选了。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容