可能有一種情況,當(dāng)在一個(gè)表中的多個(gè)重復(fù)的記錄。在獲取這些記錄,它更有意義獲取的唯一記錄,而不是獲取重復(fù)記錄。
SQL DISTINCT關(guān)鍵字,我們已經(jīng)討論過(guò),可與SELECT語(yǔ)句一起使用,以消除所有重復(fù)的記錄和獲取的唯一記錄。
DISTINCT關(guān)鍵字的基本語(yǔ)法,消除重復(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快到兩倍,這是從原始表中的一個(gè)重復(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é)果,我們沒(méi)有任何重復(fù)條目:
+----------+ | SALARY | +----------+ | 1500.00 | | 2000.00 | | 4500.00 | | 6500.00 | | 8500.00 | | 10000.00 | +----------+