SQL SELECTDISTINCTステートメント
SQL SELECTDISTINCTステートメント
このSELECT DISTINCT
ステートメントは、異なる(異なる)値のみを返すために使用されます。
テーブル内では、列に多くの重複する値が含まれていることがよくあります。また、異なる(個別の)値のみをリストしたい場合もあります。
SELECTDISTINCT構文
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 |
DISTINCTを使用しないSELECTの例
次のSQLステートメントは、「Customers」テーブルの「Country」列からすべての(重複を含む)値を選択します。
例
SELECT Country FROM Customers;
SELECT DISTINCT
それでは、ステートメントを使用して結果を見てみましょう。
SELECTDISTINCTの例
次のSQLステートメントは、「Customers」テーブルの「Country」列からDISTINCT値のみを選択します。
例
SELECT DISTINCT Country FROM Customers;
次のSQLステートメントは、さまざまな(異なる)顧客の国の数を示しています。
例
SELECT COUNT(DISTINCT Country) FROM Customers;
注:上記の例はFirefoxでは機能しません!COUNT(DISTINCT column_name)はMicrosoftAccessデータベースではサポートされていないためです。Firefoxは、この例ではMicrosoftAccessを使用しています。
MSAccessの回避策は次のとおりです。
例
SELECT Count(*) AS DistinctCountries
FROM (SELECT DISTINCT Country FROM Customers);