1.序

mysql中sql计算日期差,不能简单的相加减。

2.mysql中函数

2.1addtime()

select addtime(now(),1); -- 加1秒

2.2adddate()

有两种用法,第二个参数直接填数字的话是为日期加上指定天数,填interval的话是为日期加上指定的interval时间

select adddate(now(),1); -- 加1天

select adddate(now(), interval 1 day); -- 加1天

select adddate(now(), interval 1 hour); --加1小时

select adddate(now(), interval 1 minute); -- 加1分钟

select adddate(now(), interval 1 second); -- 加1秒

select adddate(now(), interval 1 microsecond); -- 加1毫秒

select adddate(now(), interval 1 week); -- 加1周

select adddate(now(), interval 1 month); -- 加1月

select adddate(now(), interval 1 quarter); -- 加1季

select adddate(now(), interval 1 year); -- 加1年

2.3date_add()

为日期增加一个时间间隔,只能使用interval时间作为参数,用法和adddate()一致

select date_add(now(), interval 1 day); -- 加1天

select date_add(now(), interval 1 hour); -- 加1小时

select date_add(now(), interval 1 minute); -- 加1分钟

select date_add(now(), interval 1 second); -- 加1秒

select date_add(now(), interval 1 microsecond); -- 加1毫秒

select date_add(now(), interval 1 week); -- 加1周

select date_add(now(), interval 1 month); -- 加1月

select date_add(now(), interval 1 quarter); -- 加1季

select date_add(now(), interval 1 year); -- 加1年

2.4subtime()

为日期减去指定秒数

select subtime(now(), 1); -- 减1秒

2.5subdate()

与adddate()函数用法一致,有两种用法,第二个参数直接填数字的话是为日期减去指定天数,填interval的话是为日期减去指定的interval时间

select subdate(now(),1); -- 减1天

select subdate(now(), interval 1 day); -- 减1天

select subdate(now(), interval 1 hour); --减1小时

select subdate(now(), interval 1 minute); -- 减1分钟

select subdate(now(), interval 1 second); -- 减1秒

select subdate(now(), interval 1 microsecond); -- 减1毫秒

select subdate(now(), interval 1 week); -- 减1周

select subdate(now(), interval 1 month); -- 减1月

select subdate(now(), interval 1 quarter); -- 减1季

select subdate(now(), interval 1 year); -- 减1年

2.6date_sub()

与date_add()函数用法一致,为日期减去一个时间间隔,这个只能使用interval时间作为参数

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

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

select date_sub(now(), interval 1 minute); -- 减1分钟

select date_sub(now(), interval 1 second); -- 减1秒

select date_sub(now(), interval 1 microsecond); -- 减1毫秒

select date_sub(now(), interval 1 week); -- 减1周

select date_sub(now(), interval 1 month); -- 减1月

select date_sub(now(), interval 1 quarter); -- 减1季

select date_sub(now(), interval 1 year); -- 减1年

2.7TIMESTAMPDIFF()

常用,可以实现直接比较。语法:SELECT TIMESTAMPDIFF(类型,开始时间,结束时间),计算两个日期相差的秒数、分钟数、小时数、天数、周数、季度数、月数、年数,当前日期增加或者减少一天、一周等等。

2.7.1相差的秒数

SELECT TIMESTAMPDIFF(SECOND,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'));

2.7.2相差的分钟数

SELECT TIMESTAMPDIFF(MINUTE,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'));

2.7.3相差的小时数

SELECT TIMESTAMPDIFF(HOUR,'1993-03-23 00:00:00 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'));

2.7.4相差的天数

SELECT TIMESTAMPDIFF(DAY,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))

2.7.5相差的周数

SELECT TIMESTAMPDIFF(WEEK,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))

2.7.6相差的季度数

SELECT TIMESTAMPDIFF(QUARTER,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))

2.7.7相差的月数

SELECT TIMESTAMPDIFF(MONTH,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))

2.7.8相差的年数

SELECT TIMESTAMPDIFF(YEAR,'1993-03-23 00:00:00',DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%S'))

2.7.9获取当前日期

SELECT NOW()

SELECT CURDATE()

2.7.10当前日期增加一天

SELECT DATE_SUB(CURDATE(),INTERVAL -1 DAY)

2.7.11当前日期减少一天

SELECT DATE_SUB(CURDATE(),INTERVAL 1 DAY)

2.7.12当前日期增加一周

SELECT DATE_SUB(CURDATE(),INTERVAL -1 WEEK)

SELECT DATE_SUB(NOW(),INTERVAL -1 MONTH)

SELECT DATE_SUB(CURDATE(),INTERVAL -1 WEEK)

SELECT DATE_SUB(NOW(),INTERVAL -1 MONTH)

7.13当前日期增加一月

SELECT DATE_SUB(CURDATE(),INTERVAL -1 MONTH)

FRAC_SECOND 毫秒

SECOND 秒

MINUTE 分钟

HOUR 小时

DAY 天

WEEK 星期

MONTH 月

QUARTER 季度

YEAR 年