SQL DISTINCT重複處理
可能有一種情況,當在一個表中的多個重複的記錄。在獲取這些記錄,它更有意義獲取的唯一記錄,而不是獲取重複記錄。
SQL DISTINCT關鍵字,我們已經討論過,可與SELECT語句一起使用,以消除所有重複的記錄和獲取的唯一記錄。
語法
DISTINCT關鍵字的基本語法,消除重複記錄如下:
SELECT DISTINCT column1, column2,.....columnN FROM table_name WHERE [condition]
示例:
考慮CUSTOMERS表具有以下記錄:
+----+----------+-----+-----------+----------+ | ID | NAME | AGE | ADDRESS | SALARY | +----+----------+-----+-----------+----------+ | 1 | Ramesh | 32 | Ahmedabad | 2000.00 | | 2 | Khilan | 25 | Delhi | 1500.00 | | 3 | kaushik | 23 | Kota | 2000.00 | | 4 | Chaitali | 25 | Mumbai | 6500.00 | | 5 | Hardik | 27 | Bhopal | 8500.00 | | 6 | Komal | 22 | MP | 4500.00 | | 7 | Muffy | 24 | Indore | 10000.00 | +----+----------+-----+-----------+----------+
首先,讓我們看看下麵的SELECT查詢返回重複的工資記錄:
SQL> SELECT SALARY FROM CUSTOMERS ORDER BY SALARY;
這將產生以下結果,其中薪金2000快到兩倍,這是從原始表中的一個重複的記錄。
+----------+ | SALARY | +----------+ | 1500.00 | | 2000.00 | | 2000.00 | | 4500.00 | | 6500.00 | | 8500.00 | | 10000.00 | +----------+
現在,讓我們使用DISTINCT關鍵字使用上述SELECT查詢和看到的結果:
SQL> SELECT DISTINCT SALARY FROM CUSTOMERS ORDER BY SALARY;
這將產生以下結果,我們冇有任何重複條目:
+----------+ | SALARY | +----------+ | 1500.00 | | 2000.00 | | 4500.00 | | 6500.00 | | 8500.00 | | 10000.00 | +----------+