SELECT DISTINCT语法用于仅返回不同的(different)值。
在一张表内,一列通常包含许多重复的值; 有时你只想列出不同的(different)值。
SELECT DISTINCT语句用于仅返回不同的(different)值。
SQL SELECT DISTINCT语法如下所示:
SELECT DISTINCT column1, column2, ...
FROM table_name;
在本教程中,我们将使用著名的 Northwind 样本数据库。
下面是罗斯文示例数据库中 "Customers" 表的数据:
CustomerID | CustomerName | ContactName | Address | City | PostalCode | Country |
---|---|---|---|---|---|---|
1 | Alfreds Futterkiste | Maria Anders | Obere Str. 57 | Berlin | 12209 | Germany |
2 | Ana Trujillo Emparedados y helados | Ana Trujillo | Avda. de la Constitución 2222 | México D.F. | 05021 | Mexico |
3 | Antonio Moreno Taquería | Antonio Moreno | Mataderos 2312 | México D.F. | 05023 | Mexico |
4 | Around the Horn | Thomas Hardy | 120 Hanover Sq. | London | WA1 1DP | UK |
5 | Berglunds snabbköp | Christina Berglund | Berguvsvägen 8 | Luleå | S-958 22 | Sweden |
以下SQL语句从“Customers”表中的“Country”列中选择所有(包括重复)值:
SELECT Country FROM Customers;
SELECT Country FROM Customers;
以上查询的结果:
Country
Germany
Mexico
Mexico
UK
Sweden
现在,让我们在上面的SELECT语法中使用DISTINCT关键字并查看结果。
以下SQL语句仅从"Customers" 表中的 "Country" 列中选择DISTINCT值:
查询结果:
Country
Germany
Mexico
UK
Sweden
以下SQL语句列出了不同(distinct)客户国家的数量:
注意:上述示例在Firefox和Microsoft Edge中不起作用!
由于在Microsoft Access数据库中不支持COUNT(DISTINCT column_name)。在我们的示例中Firefox和Microsoft Edge使用Microsoft Access。
现在,通过以下题目测测看您对“SQL SELECT DISTINCT(选择不同) 语法”的掌握程度吧!
SQL DISTINCT关键字:点击此处进行测试>>
更多测试题请参考:《SQL测验》题库>>
SQL AVG() 函数AVG() 函数AVG() 函数返回数字列的平均值。SQL AVG() 语法SELECT AVG(column_name)FROM table_nameWHERE...
C++ switch 语句 C++ 判断一个 switch 语句允许测试一个变量等于多个值时的情况。每个值称为一个 case,且被测试的变量会对每个 ...
C 库函数 - vprintf() C 标准库 - stdio.h描述C 库函数 int vprintf(const char *format, va_list arg) 使用参数列表发送格式化...
C 库函数 - fgetc() C 标准库 - stdio.h描述C 库函数 int fgetc(FILE *stream) 从指定的流 stream 获取下一个字符(一个无符号字...
C 库函数 - bsearch() C 标准库 - stdlib.h描述C 库函数 void *bsearch(const void *key, const void *base, size_t nitems, siz...
C 库函数 - memcpy() C 标准库 - string.h描述C 库函数 void *memcpy(void *str1, const void *str2, size_t n) 从存储区 str2 ...