Mysql - 带日期和类似的子查询

时间:2011-03-03 11:06:23

标签: mysql

我有一个包含列日期的表(类型为mysql date:yyyy-mm-dd)

我已经完成了这个请求:

Select Month(MAX(date)) AS last_month, YEAR(MAX(date)) AS last_year FROM mytable

获得去年和上个月。

我想要去年和上个月在一个请求中选择所有数据。

我如何使用以下内容:

Select * from mytable where date like 'last_year-last_month-%'

这在子查询中

3 个答案:

答案 0 :(得分:1)

这应该可以解决问题(可能不是性能最佳的解决方案):

SELECT * FROM mytable
WHERE MONTH(date) = (SELECT MONTH(MAX(date) FROM mytable))
AND YEAR(date) = (SELECT YEAR(MAX(date) FROM mytable));

编辑:更正括号。

答案 1 :(得分:1)

桌子是否在不断更新? 如果是这样,那么你可以不使用子查询,因为它们会使查询减慢很多 这将选择当月的所有内容。

SELECT * FROM mytable
WHERE MONTH(date) = MONTH(NOW())
AND YEAR(date) = YEAR(NOW())
ORDER BY date ASC

这个选择了当前和去年的所有内容。

SELECT * FROM mytable
WHERE YEAR(date) > YEAR(NOW())-1
ORDER BY date ASC

答案 2 :(得分:0)

感谢所有人,

这是一个很好的要求:

SELECT * FROM mytable
WHERE MONTH(date) = (select Month(MAX(date)) FROM mytable)
AND YEAR(date) = (select YEAR(MAX(date)) FROM mytable)
ORDER BY date ASC