Skip to content

SQL SELECT DISTINCT 语法


SELECT DISTINCT语法用于仅返回不同的(different)值。

在一张表内,一列通常包含许多重复的值; 有时你只想列出不同的(different)值。

SELECT DISTINCT语句用于仅返回不同的(different)值。

SQL SELECT DISTINCT语法如下所示:

sql
SELECT DISTINCT column1, column2, ...
FROM table_name;

演示数据库


在本教程中,我们将使用著名的 Northwind 样本数据库。

下面是罗斯文示例数据库中 "Customers" 表的数据:

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.05021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.05023Mexico
4Around the HornThomas Hardy120 Hanover Sq.LondonWA1 1DPUK
5Berglunds snabbköpChristina BerglundBerguvsvägen 8LuleåS-958 22Sweden

SELECT实例


以下SQL语句从"Customers"表中的"Country"列中选择所有(包括重复)值:
** 代码示例:**

SELECT Country FROM Customers;

sql
SELECT Country FROM Customers;

以上查询的结果:

sql
Country
Germany
Mexico
Mexico
UK

Sweden

现在,让我们在上面的SELECT语法中使用DISTINCT关键字并查看结果。


SELECT DISTINCT 实例


以下SQL语句仅从"Customers" 表中的 "Country" 列中选择DISTINCT值:

实例1

SELECT DISTINCT Country FROM Customers;

查询结果:

sql
Country
Germany
Mexico
UK
Sweden

以下SQL语句列出了不同(distinct)客户国家的数量:

实例2

SELECT COUNT(DISTINCT Country) FROM Customers;

**注意:**上述示例在Firefox和Microsoft Edge中不起作用!

由于在Microsoft Access数据库中不支持COUNT(DISTINCT column_name)。在我们的示例中Firefox和Microsoft Edge使用Microsoft Access。


章节小测


现在,通过以下题目测测看您对"SQL SELECT DISTINCT(选择不同) 语法"的掌握程度吧!

SQL DISTINCT关键字:

更多测试题请参考: