国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

SQL如何刪除重復的數據行

來源:懂視網 責編:小采 時間:2020-11-09 08:09:37
文檔

SQL如何刪除重復的數據行

SQL如何刪除重復的數據行:********************************************************** * 關于:MS SQL Server 2000 重復 記錄整理 * 作者:闞山 時間:2007-02-28 11:36 * 測試環境:SQL Server 2000 SP4 + Windows 2000 Sp1 ******
推薦度:
導讀SQL如何刪除重復的數據行:********************************************************** * 關于:MS SQL Server 2000 重復 記錄整理 * 作者:闞山 時間:2007-02-28 11:36 * 測試環境:SQL Server 2000 SP4 + Windows 2000 Sp1 ******

********************************************************** * 關于:MS SQL Server 2000 重復 記錄整理 * 作者:闞山 時間:2007-02-28 11:36 * 測試環境:SQL Server 2000 SP4 + Windows 2000 Sp1 ****************************************************

**********************************************************
* 關于:MS SQL Server 2000 重復記錄整理
* 作者:闞山 時間:2007-02-28 11:36
* 測試環境:SQL Server 2000 SP4 + Windows 2000 Sp1
**********************************************************

有兩個意義上的重復記錄,一是完全重復的記錄,也即所有字段均重復的記錄,二是部分關鍵字段重復的記錄,比如Name字段重復,而其他字段不一定重復或都重復可以忽略。
1、對于第一種重復,比較容易解決,使用
select distinct * from tableName
就可以得到無重復記錄的結果集。
如果該表需要刪除重復的記錄(重復記錄保留1條),可以按以下方法刪除
select distinct * into #Tmp from tableName
drop table tableName
select * into tableName from #Tmp
drop table #Tmp
發生這種重復的原因是表設計不周產生的,增加唯一索引列即可解決。

2、這類重復問題通常要求保留重復記錄中的第一條記錄,操作方法如下
假設有重復的字段為Name,Address,要求得到這兩個字段唯一的結果集
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不重復的結果集(但多了一個autoID字段,實際寫時可以寫在select子句中省去此列)

3、部分關鍵字段重復,且記錄中有ID.

第一種方法可一次刪除所有重復的..(只保留重復中ID最小的記錄)。
delete from table where id not in ( select min(id) from table group by name)

第二種方法每次只刪除重復中ID最大的一條記錄。
delete from table where id in ( select max(id) from table group by name having count(*)>1)

4、SQL程序刪除

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

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

SQL如何刪除重復的數據行

SQL如何刪除重復的數據行:********************************************************** * 關于:MS SQL Server 2000 重復 記錄整理 * 作者:闞山 時間:2007-02-28 11:36 * 測試環境:SQL Server 2000 SP4 + Windows 2000 Sp1 ******
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 免费观看a毛片一区二区不卡 | 成人精品视频在线 | 欧美日韩亚洲综合 | 欧美日韩精品一区二区三区视频在线 | 老司机精品视频一区二区 | 欧美 在线播放 | 日本在线不卡一区二区 | 久久久久久久国产a∨ | 日韩精品一区二区三区国语自制 | 亚洲欧美日韩中另类在线 | 久久久久久国产精品视频 | 黑人一区二区三区中文字幕 | 国产在线视频在线 | 国产午夜视频在线观看 | 欧美精品一区二区三区免费播放 | 国产成人h片视频在线观看 国产超级乱淫片中文 | 激情一区 | 午夜视频久久久久一区 | 国产精品视频久久久久 | 亚洲国产精品一区二区久久 | 国产精品一区二区三 | 国产在线精品观看 | 国产青草视频在线观看 | 日本三级韩国三级韩级在线观看 | 久久国产午夜一区二区福利 | 国内精品久久久久影院不卡 | 国产精品porn| 精品久久综合一区二区 | 亚欧美 | 国产成人亚洲欧美三区综合 | 久久午夜一区二区 | 99精品欧美一区二区三区综合在线 | 纯毛片| 欧美国产第一页 | 日韩欧美91 | 亚洲欧美另类第一页 | 欧美aⅴ在线 | 精品国产一区二区二三区在线观看 | 欧美日韩亚洲色图 | er久99久热只有精品国产 | 精品国产96亚洲一区二区三区 |