mysql获取前一天|前一月|前一年(开始结束时间)

前一天开始时间

select DATE_ADD(str_to_date(DATE_FORMAT(NOW(), '%Y-%m-%d'), '%Y-%m-%d %H:%i:%s'), INTERVAL - 1 DAY)

前一天结束时间

select DATE_ADD(DATE_ADD(str_to_date(DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 1 DAY), '%Y-%m-%d'), '%Y-%m-%d %H:%i:%s'), INTERVAL 1 DAY), INTERVAL - 1 SECOND)

前一个月开始时间

select date_sub(date_sub(date_format(now(), '%y-%m-%d 00:00:00'),interval extract(day from now()) - 1 day),interval 1 month)

前一个月结束时间

select date_sub(date_sub(date_format(now(), '%y-%m-%d 23:59:59'),interval extract(day from now()) day),interval 0 month)

前一年开始时间

select DATE_ADD(str_to_date(DATE_FORMAT(NOW(), '%Y-01-01'), '%Y-%m-%d %H:%i:%s'), INTERVAL - 1 YEAR)

前一年结束时间

select DATE_ADD(str_to_date(DATE_FORMAT(NOW(), '%Y-12-31 23:59:59'), '%Y-%m-%d %H:%i:%s'), INTERVAL - 1 YEAR)

计算总时长:返回时分秒 00:00:00

SELECT  CONCAT(SEC_TO_TIME(SUM(TIMESTAMPDIFF(SECOND,'2011-01-01 00:00:00','2011-01-01 00:00:01'))))

计算平均长:返回时分秒 00:00:00

SELECT CONCAT(SEC_TO_TIME(AVG(TIMESTAMPDIFF(SECOND,'2011-01-01 00:00:00','2011-01-01 00:00:01'))))

当前时间为几月

SELECT MONTH(NOW())

当前为本年中的第几天

SELECT DAYOFYEAR(NOW())

当前为本月第几天

SELECT DAYOFMONTH(NOW())

当前为周几:1星期日,2星期一……

SELECT DAYOFWEEK(NOW())

当前为当月第几周

SELECT weekofyear(NOW())-weekofyear(NOW()-interval day(NOW())-1 day)+1

时间格式化:2017-08-22 10:56:51

SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %T')

你可能感兴趣的:(mysql)