[英]Mysql Distinct one column but not every column
我有一张表格(汽车、年份和型号的列表),我试图仅显示年份列表,但是制造商制造汽车的年份列表可能很大。 意思是当我查询“沃尔沃”时,我会返回沃尔沃制造汽车的所有年份的列表,使用:
"SELECT id, year FROM `models_auto` WHERE `make`=? ORDER BY `year` DESC;"
然而,沃尔沃那一年可能已经生产了 50 辆汽车,而回报是所有 50 年的重复年份。 我只想返回唯一的年份列表,而不是重复的。 我看着 DISTINCT 但使用:
"SELECT DISTINCT id, year FROM `models_auto` WHERE `make`=? ORDER BY `year` DESC;"
仍然返回所有内容,因为 ID 是唯一的。 我怎么能只有不同的年份?
谢谢你。
如果您只想要年份,那么您可以使用GROUP BY
。
SELECT `year`
FROM `models_auto`
WHERE `make`=?
GROUP BY `year`
ORDER BY `year` DESC;"
或使用DISTINCT
:
SELECT DISTINCT `year`
FROM `models_auto`
WHERE `make`=?
ORDER BY `year` DESC;"
一种选择是使用group_concat()
将年份作为逗号分隔的列表返回:
select make, group_concat(distinct year order by year)
from models_auto
group by make;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.