sqlserver中distinct的用法(不重複的記錄)

來源:互聯網
上載者:User

標籤:使用   資料   sql   table   資訊   rom   簡單   server   

下面先來看看例子:

table表

欄位1     欄位2
   id        name
   1           a
   2           b
   3           c
   4           c
   5           b

庫結構大概這樣,這隻是一個簡單的例子,實際情況會複雜得多。

比如我想用一條語句查詢得到name不重複的所有資料,那就必須

使用distinct去掉多餘的重複記錄。

select distinct name from table
得到的結果是: 

---------- 

name
   a

   c

好像達到效果了,可是,我想要得到的是id值呢?改一下查詢語句吧:

select distinct name, id from table

結果會是:

---------- 

id name
   1 a
   2 b
   3 c
   4 c
   5 b

distinct怎麼沒起作用?作用是起了的,不過他同時作用了兩個

欄位,也就是必須得id與name都相同的才會被排除

我們再改改查詢語句:

select id, distinct name from table

很遺憾,除了錯誤資訊你什麼也得不到,distinct必須放在開頭。難到不能把distinct放到where條件裡?能,照樣報錯。

--------------------------------------------------------

下面方法可行:

select *, count(distinct name) from table group by name

結果:

   id name count(distinct name)
   1 a 1
   2 b 1
   3 c 1

最後一項是多餘的,不用管就行了,目的達到

group by 必須放在 order by 和 limit之前,不然會報錯

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.