校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > sql刪除重復數據的詳細方法

sql刪除重復數據的詳細方法

熱門標簽:榕城市地圖標注 慶陽地圖標注 怎么給高德做地圖標注 浙江穩定外呼系統供應商 北京400電話辦理多少錢 電銷外呼系統軟件功能 咸陽電腦外呼系統運營商 承德地圖標注公司名需要花錢嗎 美團地圖標注商戶認證注冊

一. 刪除完全重復的記錄

完全重復的數據,通常是由于沒有設置主鍵/唯一鍵約束導致的。
測試數據:

復制代碼 代碼如下:

if OBJECT_ID('duplicate_all') is not null
drop table duplicate_all
GO
create table duplicate_all
(
c1 int,
c2 int,
c3 varchar(100)
)
GO
insert into duplicate_all
select 1,100,'aaa' union all
select 1,100,'aaa' union all
select 1,100,'aaa' union all
select 1,100,'aaa' union all
select 1,100,'aaa' union all
select 2,200,'bbb' union all
select 3,300,'ccc' union all
select 4,400,'ddd' union all
select 5,500,'eee'
GO

(1) 借助臨時表

利用DISTINCT得到單條記錄,刪除源數據,然后導回不重復記錄。
如果表不大的話,可以把所有記錄導出一次,然后truncate表后再導回,這樣可以避免delete的日志操作。

復制代碼 代碼如下:

if OBJECT_ID('tempdb..#tmp') is not null
drop table #tmp
GO
select distinct * into #tmp
from duplicate_all
where c1 = 1
GO
delete duplicate_all where c1 = 1
GO
insert into duplicate_all
select * from #tmp

(2) 使用ROW_NUMBER
復制代碼 代碼如下:

with tmp
as
(
select *,ROW_NUMBER() OVER(PARTITION BY c1,c2,c3 ORDER BY(getdate())) as num
from duplicate_all
where c1 = 1
)
delete tmp where num > 1

如果多個表有完全重復的行,可以考慮通過UNION將多個表聯合,插到一個新的同結構的表,SQL Server會幫助去掉表和表之間的重復行。

二. 刪除部分重復的記錄

部分列重復的數據,通常表上是有主鍵的,可能是程序邏輯造成了多行數據列值的重復。
測試數據:

復制代碼 代碼如下:

if OBJECT_ID('duplicate_col') is not null
drop table duplicate_col
GO
create table duplicate_col
(
c1 int primary key,
c2 int,
c3 varchar(100)
)
GO
insert into duplicate_col
select 1,100,'aaa' union all
select 2,100,'aaa' union all
select 3,100,'aaa' union all
select 4,100,'aaa' union all
select 5,500,'eee'
GO

(1) 唯一索引

唯一索引有個忽略重復建的選項,在創建主鍵約束/唯一鍵約束時都可以使用這個索引選項。

復制代碼 代碼如下:

if OBJECT_ID('tmp') is not null
drop table tmp
GO
create table tmp
(
c1 int,
c2 int,
c3 varchar(100),
constraint UQ_01 unique(c2,c3) with(IGNORE_DUP_KEY = ON)
)
GO
insert into tmp
select * from duplicate_col
select * from tmp

(2) 借助主鍵/唯一鍵來刪除
通常會選擇主鍵/唯一鍵的最大/最小值保留,其他行刪除。以下只保留重復記錄中c1最小的行。
復制代碼 代碼如下:

delete from duplicate_col
where exists(select 1 from duplicate_col b where duplicate_col.c1 > b.c1 and (duplicate_col.c2 = b.c2 and duplicate_col.c3 = b.c3))

--或者
復制代碼 代碼如下:

delete from duplicate_col
where c1 not in (select min(c1) from duplicate_col group by c2,c3)

如果要保留重復記錄中的第N行,可以參考05.取分組中的某幾行。
(3) ROW_NUMBER
和刪除完全重復記錄的寫法基本一樣。
復制代碼 代碼如下:

with tmp
as
(
select *,ROW_NUMBER() OVER(PARTITION BY c2,c3 ORDER BY(getdate())) as num
from duplicate_col
)
delete tmp where num > 1
select * from duplicate_col


SQL刪除重復數據只保留一條 (下面的代碼,很多網友反饋錯誤,大家多測試)

用SQL語句,刪除掉重復項只保留一條
在幾千條記錄里,存在著些相同的記錄,如何能用SQL語句,刪除掉重復的呢
1、查找表中多余的重復記錄,重復記錄是根據單個字段(peopleId)來判斷
select * from people
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
2、刪除表中多余的重復記錄,重復記錄是根據單個字段(peopleId)來判斷,只留有rowid最小的記錄
delete from people
where   peopleName in (select peopleName    from people group by peopleName      having count(peopleName) > 1)
and   peopleId not in (select min(peopleId) from people group by peopleName     having count(peopleName)>1)
3、查找表中多余的重復記錄(多個字段)
select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
4、刪除表中多余的重復記錄(多個字段),只留有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、查找表中多余的重復記錄(多個字段),不包含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)  
6.消除一個字段的左邊的第一位:
update tableName set [Title]=Right([Title],(len([Title])-1)) where Title like '村%'
7.消除一個字段的右邊的第一位:
update tableName set [Title]=left([Title],(len([Title])-1)) where Title like '%村'
8.假刪除表中多余的重復記錄(多個字段),不包含rowid最小的記錄
update vitae set ispass=-1
where peopleId in (select peopleId from vitae group by peopleId

您可能感興趣的文章:
  • 刪除mysql數據庫中的重復數據記錄
  • 教你幾種在SQLServer中刪除重復數據方法
  • sqlserver中重復數據值只取一條的sql語句
  • 分享MYSQL插入數據時忽略重復數據的方法
  • MYSQL刪除重復數據的簡單方法
  • MySQL 刪除數據庫中重復數據方法小結
  • 刪除MySQL重復數據的方法
  • MySQL中刪除重復數據的簡單方法
  • MySQL處理重復數據的方法
  • 很全面的MySQL處理重復數據代碼

標簽:呼和浩特 昭通 上海 新鄉 拉薩 重慶 江蘇 貴州

巨人網絡通訊聲明:本文標題《sql刪除重復數據的詳細方法》,本文關鍵詞  sql,刪除,重復,數據,的,詳細,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sql刪除重復數據的詳細方法》相關的同類信息!
  • 本頁收集關于sql刪除重復數據的詳細方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    色哟哟欧美精品| 欧美zozo另类异族| 亚洲老司机在线| 91同城在线观看| 亚洲婷婷国产精品电影人久久| 亚洲chinese男男1069| 欧美亚洲国产一区二区三区va| 亚洲激情一二三区| 欧美在线一二三四区| 亚洲综合久久久| 欧美日韩免费不卡视频一区二区三区| 亚洲第一主播视频| 91精品午夜视频| 日本不卡视频一二三区| 欧美一卡2卡3卡4卡| 蜜臀av一区二区| 欧美不卡一区二区三区四区| 黑人巨大精品欧美一区| 久久久综合九色合综国产精品| 国产精品1区2区3区| 国产欧美一区二区三区沐欲| 不卡在线视频中文字幕| 国产精品国产三级国产| 91福利精品第一导航| 天堂av在线一区| 欧美videossexotv100| 国产成人亚洲综合a∨婷婷图片| 亚洲国产电影在线观看| 91农村精品一区二区在线| 伊人夜夜躁av伊人久久| 欧美丰满少妇xxxbbb| 狠狠色丁香久久婷婷综| 国产欧美一区二区三区鸳鸯浴| 91丨九色porny丨蝌蚪| 亚洲一区自拍偷拍| 欧美一区二区视频在线观看2020 | 综合久久久久久| 在线影院国内精品| 日本不卡123| 国产亚洲va综合人人澡精品| av爱爱亚洲一区| 亚洲国产中文字幕在线视频综合| 日韩视频一区二区| 成人av在线电影| 亚洲午夜免费电影| 精品欧美久久久| 99九九99九九九视频精品| 亚洲h动漫在线| 久久久综合视频| 在线视频亚洲一区| 久久av老司机精品网站导航| 国产精品青草久久| 欧美卡1卡2卡| 丰满少妇在线播放bd日韩电影| 一区二区高清在线| 日韩欧美一区二区免费| 粉嫩高潮美女一区二区三区 | 亚洲成人精品一区| 欧美精品一区二区精品网| 99视频超级精品| 日韩电影在线免费观看| 日本一区二区视频在线| 欧美精品v日韩精品v韩国精品v| 国产一区999| 亚洲成人一区在线| 久久久久九九视频| 欧美日韩一区二区在线观看视频| 国产精品123| 亚洲第一激情av| 国产精品亲子乱子伦xxxx裸| 91精品综合久久久久久| 成年人国产精品| 蜜桃一区二区三区在线观看| 最新中文字幕一区二区三区| 91精品国产aⅴ一区二区| av电影在线观看完整版一区二区 | 亚洲中国最大av网站| 久久久精品天堂| 欧美疯狂性受xxxxx喷水图片| 成人精品一区二区三区四区 | www.爱久久.com| 精品一二线国产| 夜夜亚洲天天久久| 国产日产欧美一区| 日韩欧美一级在线播放| 色欧美片视频在线观看在线视频| 国产精品99久久不卡二区| 三级不卡在线观看| 亚洲黄色免费网站| 国产精品色呦呦| 精品国产百合女同互慰| 欧美视频精品在线| 91网站在线观看视频| 国产成人午夜99999| 男人操女人的视频在线观看欧美| 亚洲激情自拍偷拍| 国产精品美日韩| 久久青草国产手机看片福利盒子 | 91精品国产综合久久小美女| 99久久99精品久久久久久| 国产成人亚洲综合a∨猫咪| 美日韩黄色大片| 婷婷六月综合亚洲| 一区二区视频免费在线观看| 国产精品色婷婷久久58| 精品国产91乱码一区二区三区 | av在线不卡电影| 国产剧情一区二区| 国内欧美视频一区二区 | 亚洲国产日韩精品| 亚洲另类在线制服丝袜| 1区2区3区欧美| 国产精品久久久久久久午夜片| 国产午夜精品一区二区| 精品国产一区久久| 日韩精品专区在线影院重磅| 欧美一级专区免费大片| 337p亚洲精品色噜噜狠狠| 欧美猛男gaygay网站| 精品婷婷伊人一区三区三| 欧美性xxxxxxxx| 欧美日韩免费一区二区三区视频| 欧美伊人久久大香线蕉综合69| 91麻豆自制传媒国产之光| 99综合电影在线视频| 不卡的电影网站| 99精品热视频| 91丨porny丨首页| 91麻豆精品一区二区三区| 99精品国产99久久久久久白柏 | 国产一区二区在线看| 国内精品久久久久影院薰衣草| 国产自产2019最新不卡| 国产夫妻精品视频| 国产99一区视频免费| 暴力调教一区二区三区| 91香蕉视频污在线| 在线免费观看日本一区| 欧美日韩精品一区二区三区四区| 欧美蜜桃一区二区三区| 欧美一级二级三级蜜桃| 精品国精品国产| 欧美韩日一区二区三区| 一色桃子久久精品亚洲| 亚洲精品国产精品乱码不99 | 日韩精品久久久久久| 麻豆精品一区二区av白丝在线| 麻豆成人久久精品二区三区红 | 欧美伊人久久大香线蕉综合69| 欧美中文字幕一区二区三区亚洲| 欧美日韩高清一区| 精品三级av在线| 国产精品私人自拍| 日韩码欧中文字| 亚洲观看高清完整版在线观看| 日本免费新一区视频| 国内精品伊人久久久久av一坑| 成人午夜视频网站| 欧洲亚洲国产日韩| 日韩精品一区二区在线观看| 欧美激情中文字幕| 一级日本不卡的影视| 免费久久99精品国产| 国产精品一区二区在线观看网站| www.色精品| 欧美日本一区二区| 久久综合成人精品亚洲另类欧美| 国产精品丝袜一区| 亚洲国产精品自拍| 久久成人免费日本黄色| jvid福利写真一区二区三区| 欧美日韩性生活| 久久久精品黄色| 夜夜嗨av一区二区三区四季av| 强制捆绑调教一区二区| 国产成人在线色| 欧美日韩卡一卡二| 国产日韩欧美麻豆| 亚洲成人激情社区| 国产成人aaa| 欧美日韩在线一区二区| 久久一二三国产| 亚洲韩国一区二区三区| 国产伦精品一区二区三区在线观看 | 国产98色在线|日韩| 在线视频你懂得一区| 精品国产制服丝袜高跟| 亚洲欧美视频在线观看视频| 美日韩一级片在线观看| 91片黄在线观看| 精品成人在线观看| 一区二区在线观看视频| 久久99热国产| 欧美在线|欧美| 欧美经典一区二区三区| 日韩av在线免费观看不卡| av电影一区二区| 精品理论电影在线| 亚洲国产精品久久久男人的天堂| 国产aⅴ综合色|