美文网首页
mysql时间计算函数

mysql时间计算函数

作者: Eleganty | 来源:发表于2018-03-29 11:04 被阅读0次

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

    相关文章

      网友评论

          本文标题:mysql时间计算函数

          本文链接:https://www.haomeiwen.com/subject/pcxmcftx.html