SQL DISTINCT關(guān)鍵字與SELECT語句一起使用,以消除所有重復(fù)的記錄和獲取的唯一記錄。
可能有一種情況,當(dāng)你在一個表中多個重復(fù)的記錄。 當(dāng)獲取這些記錄,它獲取的唯一記錄更有意義,而不是獲取重復(fù)記錄。
DISTINCT關(guān)鍵字的基本語法,以消除重復(fù)記錄如下:
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查詢返回重復(fù)的工資記錄:
SQL> SELECT SALARY FROM CUSTOMERS ORDER BY SALARY;
這將產(chǎn)生以下結(jié)果,其中薪水為2000的出現(xiàn)兩次,這是原始表中的一個重復(fù)記錄。
+----------+ | SALARY | +----------+ | 1500.00 | | 2000.00 | | 2000.00 | | 4500.00 | | 6500.00 | | 8500.00 | | 10000.00 | +----------+
現(xiàn)在,讓我們使用DISTINCT關(guān)鍵字使用上述SELECT查詢并看到結(jié)果:
SQL> SELECT DISTINCT SALARY FROM CUSTOMERS ORDER BY SALARY;
這將產(chǎn)生以下結(jié)果,我們沒有任何重復(fù)記錄:
+----------+ | SALARY | +----------+ | 1500.00 | | 2000.00 | | 4500.00 | | 6500.00 | | 8500.00 | | 10000.00 | +----------+