MySQL使用date_add()和date_sub(),实现日期操作

定义:

(1)date_add()为日期增加一个时间间隔

date_add(current_date ,INTERVAL 1 second)    -- 当前时间加1秒
date_add(current_date ,INTERVAL 1 minut)    -- 当前时间加1分钟
date_add(current_date ,INTERVAL 1 hour)    -- 当前时间加1小时
date_add(current_date ,INTERVAL 1 day)    -- 当前时间加1天  
date_add(current_date ,INTERVAL 1 year)    -- 当前时间加1年

(2)

<![CDATA[ ]]>:如果写的sql中有一些特殊的字符的话,在解析xml文件的时候会被转义,但我们不希望他被转义,所以我们要使用<![CDATA[ ]]>来解决

(3)date_sub()为日期减少一个时间间隔

语法格式为:  DATE_SUB(date,INTERVAL expr type)

#date 指定的时间,可以是now(),也可以是其它时间
#INTERVAL 间隔关键字
#expr 添加的时间间隔
#type 时间间隔单位

date_sub(now(), interval 1 day) - 减1天

date_sub(now(), interval 1 hour) -减1小时

date_sub(now(),interval 1 second)   当前时间减少1秒

实操:

SELECT t.id
FROM registry AS t
WHERE t.update_time <![CDATA[ < ]]> DATE_ADD(#{nowTime},INTERVAL -#{timeout} SECOND)

m

统计当注册表的更新时间小于当前时间-超时时间(没有超时的时间)的id集合

例2:

UPDATE  表   

set  A_start_time = B_time, A_end_time = date_add(B_time, interval 2 hour)

where  条件

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值