我有以下查询:
select carBrand, carYear, carModel from cars;
我想要的是只获得不同的汽车名称。
我写了这个,但这不是我想要的。
select DISTINCT carBrand, carYear, carModel from Cars;
我怎么解决这个问题?
我有以下查询:
select carBrand, carYear, carModel from cars;
我想要的是只获得不同的汽车名称。
我写了这个,但这不是我想要的。
select DISTINCT carBrand, carYear, carModel from Cars;
我怎么解决这个问题?
DISTINCT 适用于整行,而不是特定列。如果要获取唯一名称,请仅选择该列。
SELECT DISTINCT carBrand FROM Cars
尝试
SELECT carBrand , carYear ,carModel
FROM Cars
GROUP BY carBrand , carYear ,carModel;
我不确定为什么接受的答案已被接受,当然也不明白为什么它被赞成,但 OP 在问题中有以下内容:
我写了这个,但这不是我想要的。
select DISTINCT carBrand, carYear, carModel from Cars;
接受的答案建议使用:
SELECT carBrand , carYear ,carModel
FROM Cars
GROUP BY carBrand , carYear ,carModel;
它返回与 OP 查询完全相同的结果。实际上,甚至不鼓励将答案中的建议(使用 group by)用于获得不同的结果,而应将其用于聚合。有关更多信息,请参阅此答案。
此外,SQL Server 足够聪明,可以理解如果查询中没有聚合函数,那么查询实际上是在请求,distinct
所以它会distinct
在后台使用。
正如@MarkByers 在他的回答中所指出的那样, Distinct 将对整行执行不同的操作。
对于那些想要测试上述内容的人,这里有一个脚本,它将创建一个包含 3 列的表,然后用数据填充它。(distinct
和group by
) 都将返回相同的结果集。
CREATE TABLE [dbo].[Cars](
[carBrand] [varchar](50) NULL,
[carYear] [int] NULL,
[carModel] [varchar](50) NULL
)
go;
insert into Cars values('BMW', 2000, '328 i');
insert into Cars values('BMW', 2000, '328 i');
insert into Cars values('BMW', 2000, '328 i');
insert into Cars values('BMW', 2000, '3M');
两个查询都将返回以下结果:
carBrand carYear carModel
BMW 2000 328 i
BMW 2000 3M
结论
group by
如果您想要不同的记录,请勿使用。使用distinct
. 使用group by
聚合函数时使用,例如SUM
等COUNT
。
这取决于你想要什么。例如,如果您想要“Toyota Corolla”和“Toyota Camry”,但忽略年份,那么您可以这样做:
SELECT DISTINCT carBrand + ' ' + carModel AS carName
FROM Cars;