天天看點

**SQL某一表中重複某一字段重複記錄查詢與處理

sql某一表中重複某一字段重複記錄查詢與處理

1.查詢出重複記錄

 select 重複記錄字段 form  資料表 group by houseno having count(重複記錄字段)>1

2.重複記錄隻顯示一條ID值最小或最大的記錄

 select   id,* from   資料表 where houseno (select 重複記錄字段 form 資料表 group by 重複記錄

字段 having count(重複記錄字段)>1 )

這樣把houseno重複的的ID值全部顯示出,那麼我們如何隻顯示一條id最小或最大的記錄呢?

關鍵是在上面sql的where子句中select 重複記錄字段 form 資料表 group by 重複記錄字段 having count(

重複記錄字段)>1

修改為

select min(id) form 資料表 group by 重複記錄字段 having count(重複記錄字段)>1

這樣就查詢重複記錄字段中ID最小值

那麼上面的語句就是

  select   id,* from   資料表 where houseno (select min(id) form 資料表 group by 重複記錄字段

having count(重複記錄字段)>1 )

3.至于對重複記錄執行delete update 就非常簡單啦

  例如隻保留最小id的一條

   delete 資料表 where id in (select max(id ) from 資料包 group by 重複記錄字段 having count(重

複記錄字段)>1)

 update 操作不說啦都一樣。

4.group by  字段 having count與distinct的差別

distct查詢顯示全部字段值都是一樣的唯一,一條記錄

 例如

id     name   sex

43 111 1

44 111 1

45 111 2

46 222 2

47 222 2

48 333 1

49 333 1

SELECT distinct

      [name]

      ,[sex]

  FROM [database].[dbo].[a]

要想實作上面的要去掉 sex字段 改成

但要想取得重複ID最小值不建議用distinct。

總結:

 對于重複記錄關鍵是查出 :采用group by 字段 having count(字段)>1 

 取得最小id的一條(很關鍵) :采用min(id)

如何聯系我:【萬裡虎】www.bravetiger.cn

【QQ】3396726884 (咨詢問題100元起,幫助解決問題500元起)

【部落格】http://www.cnblogs.com/kenshinobiy/