mysql计算时间函数_mysql时间计算函数

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

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

3771ec33b162

图1

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

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

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

3771ec33b162

图2

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

3771ec33b162

图3

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值