我有一个包含列日期的表(类型为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-%'
这在子查询中
答案 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