根据当前日期获取前3个月的数据 - MySQL

时间:2011-09-21 10:16:30

标签: mysql sql

如何使用SQL语句获取前3个月的数据?例如,如果当前日期是01/01/2012,那么如何获取2011年11月,11月,10月的数据?

请有人指导我。

1 个答案:

答案 0 :(得分:13)

SELECT * FROM table1 
WHERE mydate BETWEEN DATE_SUB(now(), INTERVAL 3 MONTH) AND now()

或者如果你想留在几个月内

SELECT * FROM table1 
WHERE MONTH(mydate) BETWEEN MONTH(DATE_SUB(now(), INTERVAL 3 MONTH)) AND MONTH(now())
  AND YEAR(mydate) BETWEEN YEAR(DATE_SUB(now(), INTERVAL 3 MONTH)) AND YEAR(now())

后一个版本的运行速度要慢得多,因为它不能使用mydate的索引。