欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

用SQL刪除重復(fù)記錄的N種方法

系統(tǒng) 1880 0

例如:
id?????????? name???????? value
1?????????????? a???????????????? pp
2?????????????? a???????????????? pp
3?????????????? b???????????????? iii
4?????????????? b???????????????? pp
5?????????????? b???????????????? pp
6?????????????? c???????????????? pp
7?????????????? c???????????????? pp
8?????????????? c???????????????? iii
id是主鍵
要求得到這樣的結(jié)果
id?????????? name???????? value
1?????????????? a???????????????? pp
3?????????????? b???????????????? iii
4?????????????? b???????????????? pp
6?????????????? c???????????????? pp
8?????????????? c???????????????? iii

方法1
delete?? YourTable??
where?? [id]?? not?? in?? (
select?? max([id])?? from?? YourTable??
group?? by?? (name?? +?? value))

方法2
delete?? a
from?? 表?? a?? left?? join(
select?? id=min(id)?? from?? 表?? group?? by?? name,value
)b?? on?? a.id=b.id
where?? b.id?? is?? null



查詢及刪除重復(fù)記錄的SQL語句
查詢及刪除重復(fù)記錄的SQL語句
1、查找表中多余的重復(fù)記錄,重復(fù)記錄是根據(jù)單個字段(peopleId)來判斷
select * from people
where peopleId in (select?? peopleId from?? people group by?? peopleId having count(peopleId) > 1)
2、刪除表中多余的重復(fù)記錄,重復(fù)記錄是根據(jù)單個字段(peopleId)來判斷,只留有rowid最小的記錄
delete from people
where peopleId in (select?? peopleId from people group by?? peopleId?? having count(peopleId) > 1)
and rowid not in (select min(rowid) from?? people group by peopleId having count(peopleId )>1)
3、查找表中多余的重復(fù)記錄(多個字段)
select * from vitae a
where (a.peopleId,a.seq) in?? (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
4、刪除表中多余的重復(fù)記錄(多個字段),只留有rowid最小的記錄
delete from vitae a
where (a.peopleId,a.seq) in?? (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)

5、查找表中多余的重復(fù)記錄(多個字段),不包含rowid最小的記錄
select * from vitae a
where (a.peopleId,a.seq) in?? (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
(二)
比方說
在A表中存在一個字段“name”,
而且不同記錄之間的“name”值有可能會相同,
現(xiàn)在就是需要查詢出在該表中的各記錄之間,“name”值存在重復(fù)的項;
Select Name,Count(*) From A Group By Name Having Count(*) > 1
如果還查性別也相同大則如下:
Select Name,sex,Count(*) From A Group By Name,sex Having Count(*) > 1

(三)
方法一
declare @max integer,@id integer
declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) >; 1
open cur_rows
fetch cur_rows into @id,@max
while @@fetch_status=0
begin
select @max = @max -1
set rowcount @max
delete from 表名 where 主字段 = @id
fetch cur_rows into @id,@max
end
close cur_rows
set rowcount 0 方法二
"重復(fù)記錄"有兩個意義上的重復(fù)記錄,一是完全重復(fù)的記錄,也即所有字段均重復(fù)的記錄,二是部分關(guān)鍵字段重復(fù)的記錄,比如Name字段重復(fù),而其他字段不一定重復(fù)或都重復(fù)可以忽略。
1、對于第一種重復(fù),比較容易解決,使用
select distinct * from tableName
就可以得到無重復(fù)記錄的結(jié)果集。
如果該表需要刪除重復(fù)的記錄(重復(fù)記錄保留1條),可以按以下方法刪除
select distinct * into #Tmp from tableName
drop table tableName
select * into tableName from #Tmp
drop table #Tmp
發(fā)生這種重復(fù)的原因是表設(shè)計不周產(chǎn)生的,增加唯一索引列即可解決。
2、這類重復(fù)問題通常要求保留重復(fù)記錄中的第一條記錄,操作方法如下
假設(shè)有重復(fù)的字段為Name,Address,要求得到這兩個字段唯一的結(jié)果集
select identity(int,1,1) as autoID, * into #Tmp from tableName
select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID
select * from #Tmp where autoID in(select autoID from #tmp2)
最后一個select即得到了Name,Address不重復(fù)的結(jié)果集(但多了一個autoID字段,實際寫時可以寫在select子句中省去此列)
(四)
查詢重復(fù)
select * from tablename where id in (
select id from tablename
group by id
having count(id) > 1
)

用SQL刪除重復(fù)記錄的N種方法


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 一级黄色绿像片 | 国产视频网站在线观看 | 欧美交 | 久久久国产精品 | 久久精品99久久 | 亚洲婷婷综合网 | 91成人在线免费 | 97理论三级九七午夜在线观看 | 日本玖玖 | 中文视频在线 | 欧美日韩一区二区在线 | 日韩欧美专区 | 国产在线观 | 特级做a爰片毛片免费看 | 看毛片网站 | 午夜在线观看免费视频 | 国产一级做a爰片在线 | 亚洲美女在线播放 | 久草6 | 国产大伊香蕉精品视频 | 午夜爱爱爱爱爽爽爽网站免费 | 午夜在线观看免费视频 | 大伊香蕉精品视频在线天堂 | 国内外成人免费视频 | 成人性生活视频在线播放 | 三级网站免费看 | 男女啪啪高清无遮挡 | 狠狠操社区| 爱草在线 | 亚洲综合天堂网 | 欧美高清3dfreexxxx性 | 狠狠操天天操夜夜操 | 高清乱码一卡二卡插曲A | 凹凸日日摸日日碰夜夜爽孕妇 | 日韩黄色影视 | 一级毛片丰满 出奶水 | 精品一区视频 | 国产成人区 | 精品日韩欧美一区二区三区在线播放 | 精品久久一区二区三区 | 免费黄色片网站 |