mysql中去重 distinct 用法


在使用mysql時,有時需要查詢出某個字段不重復的記錄,這時可以使用mysql提供的distinct這個關鍵字來過濾重復的記錄,但是實際中我們往往用distinct來返回不重復字段的條數(count(distinct id)),其原因是distinct只能返回他的目標字段,而無法返回其他字段,例如有如下表user:

 

用distinct來返回不重復的用戶名:select distinct name from user;,結果為:

 

這樣只把不重復的用戶名查詢出來了,但是用戶的id,並沒有被查詢出來:select distinct name,id from user;,這樣的結果為:

 

distinct name,id 這樣的mysql 會認為要過濾掉name和id兩個字段都重復的記錄,如果sql這樣寫:select id,distinct name from user,這樣mysql會報錯,因為distinct必須放在要查詢字段的開頭。

所以一般distinct用來查詢不重復記錄的條數。

如果要查詢不重復的記錄,有時候可以用group by :

select id,name from user group by name;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM