当前一个业务需求,需要查找创建在三天以前的数据,表中是存了一个创建时间的;这个需求看起来很简单,直接全部查找出来然后用代码根据时间筛选一下就可以了。但这只是适用于数据量不大的情况下,如果数据量大,又要分页的话,还用代码实现的话,很可能会造成内存不足的问题。我认为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秒,依此类推,然后就可以直接做筛选了。
网友评论