mysql时间计算函数

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

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


mysql时间计算函数_第1张图片
图1

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

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

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


mysql时间计算函数_第2张图片
图2

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


mysql时间计算函数_第3张图片
图3

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

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

你可能感兴趣的:(mysql时间计算函数)