日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Oracle中查找和刪除重復記錄方法簡介

瀏覽:19日期:2023-11-24 18:42:17
平時工作中可能會碰到當試圖對庫表中的某一列或幾列創建唯一索引時,系統提示 ORA-01452 :不能創建唯一索引,發現重復記錄。 下面總結一下幾種查找和刪除重復記錄的方法(以表CZ為例): 表CZ的結構如下: SQL> desc czName Null? Type----------------------------------------- C1 NUMBER(10)C10 NUMBER(5)C20 VARCHAR2(3)刪除重復記錄的方法原理: (1).在Oracle中,每一條記錄都有一個rowid,rowid在整個數據庫中是唯一的,rowid確定了每條記錄是在Oracle中的哪一個數據文件、塊、行上。 (2).在重復的記錄中,可能所有列的內容都相同,但rowid不會相同,所以只要確定出重復記錄中那些具有最大rowid的就可以了,其余全部刪除。 重復記錄判定的標準是: C1,C10和C20這三列的值都相同才算是重復記錄。 經查看表CZ總共有16條記錄: SQL>set pagesize 100SQL>select * from cz;C1 C10 C20---------- ---------- ---1 2 dsf1 2 dsf1 2 dsf1 2 dsf2 3 che1 2 dsf1 2 dsf1 2 dsf1 2 dsf2 3 che2 3 che2 3 che2 3 che3 4 dff3 4 dff3 4 dff4 5 err5 3 dar6 1 wee7 2 zxc20 rows selected.1.查找重復記錄的幾種方法: (1).SQL>select * from cz group by c1,c10,c20 having count(*) >1;C1 C10 C20---------- ---------- ---1 2 dsf2 3 che3 4 dff(2).SQL>select distinct * from cz;C1 C10 C20---------- ---------- ---1 2 dsf2 3 che3 4 dff(3).SQL>select * from cz a where rowid=(select max(rowid) from cz where c1=a.c1 and c10=a.c10 and c20=a.c20);C1 C10 C20---------- ---------- ---1 2 dsf2 3 che3 4 dff2.刪除重復記錄的幾種方法: (1).適用于有大量重復記錄的情況(在C1,C10和C20列上建有索引的時候,用以下語句效率會很高): SQL>delete cz where (c1,c10,c20) in (select c1,c10,c20 from cz group by c1,c10,c20 having count(*)>1) and rowid not in(select min(rowid) from cz group by c1,c10,c20 having count(*)>1);SQL>delete cz where rowid not in(select min(rowid) from cz group by c1,c10,c20);(2).適用于有少量重復記錄的情況(注重,對于有大量重復記錄的情況,用以下語句效率會很低): SQL>delete from cz a where a.rowid!=(select max(rowid) from cz b where a.c1=b.c1 and a.c10=b.c10 and a.c20=b.c20);SQL>delete from cz a where a.rowid<(select max(rowid) from cz b where a.c1=b.c1 and a.c10=b.c10 and a.c20=b.c20);SQL>delete from cz a where rowid <(select max(rowid) from cz where c1=a.c1 and c10=a.c10 and c20=a.c20);(3).適用于有少量重復記錄的情況(臨時表法): SQL>create table test as select distinct * from cz; (建一個臨時表test用來存放重復的記錄)SQL>truncate table cz; (清空cz表的數據,但保留cz表的結構)SQL>insert into cz select * from test; (再將臨時表test里的內容反插回來)(4).適用于有大量重復記錄的情況(Exception into 子句法): 采用alter table 命令中的 Exception into 子句也可以確定出庫表中重復的記錄。這種方法稍微麻煩一些,為了使用“excepeion into ”子句,必須首先創建 EXCEPTIONS 表。創建該表的 SQL 腳本文件為 utlexcpt.sql 。對于win2000系統和 UNIX 系統, Oracle 存放該文件的位置稍有不同,在win2000系統下,該腳本文件存放在$ORACLE_HOMEOra90rdbmsadmin 目錄下;而對于 UNIX 系統,該腳本文件存放在$ORACLE_HOME/rdbms/admin 目錄下。 具體步驟如下: SQL>@?/rdbms/admin/utlexcpt.sqlTable created.SQL>desc exceptionsName Null? Type----------------------------------------- ROW_ID ROWIDOWNER VARCHAR2(30)TABLE_NAME VARCHAR2(30)CONSTRAINT VARCHAR2(30)SQL>alter table cz add constraint cz_unique unique(c1,c10,c20) exceptions into exceptions; *ERROR at line 1:ORA-02299: cannot validate (TEST.CZ_UNIQUE) - duplicate keys foundSQL>create table dups as select * from cz where rowid in (select row_id from exceptions); Table created.SQL>select * from dups; C1 C10 C20---------- ---------- ---1 2 dsf1 2 dsf1 2 dsf1 2 dsf2 3 che1 2 dsf1 2 dsf1 2 dsf1 2 dsf2 3 che2 3 che2 3 che2 3 che3 4 dff3 4 dff3 4 dff16 rows selected.SQL>select row_id from exceptions;ROW_ID------------------AAAHD/AAIAAAADSAAAAAAHD/AAIAAAADSAABAAAHD/AAIAAAADSAACAAAHD/AAIAAAADSAAFAAAHD/AAIAAAADSAAHAAAHD/AAIAAAADSAAIAAAHD/AAIAAAADSAAGAAAHD/AAIAAAADSAADAAAHD/AAIAAAADSAAEAAAHD/AAIAAAADSAAJAAAHD/AAIAAAADSAAKAAAHD/AAIAAAADSAALAAAHD/AAIAAAADSAAMAAAHD/AAIAAAADSAANAAAHD/AAIAAAADSAAOAAAHD/AAIAAAADSAAP16 rows selected.SQL>delete from cz where rowid in ( select row_id from exceptions);16 rows deleted.SQL>insert into cz select distinct * from dups;3 rows created.SQL>select *from cz;C1 C10 C20---------- ---------- ---1 2 dsf2 3 che3 4 dff4 5 err5 3 dar6 1 wee7 2 zxc7 rows selected.從結果里可以看到重復記錄已經刪除。
標簽: Oracle 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久香蕉精品香蕉| 日韩国产欧美| 亚洲国产一区二区三区在线播放| 欧美激情国产在线| 亚洲成人不卡| 一区三区视频| 中文在线一区| 丝袜美腿一区二区三区| 亚洲欧美日本日韩| 日韩精品亚洲专区| 国产欧美二区| 中国字幕a在线看韩国电影| 欧美亚洲二区| 国产精品成久久久久| 麻豆理论在线观看| 欧美日韩一二| 亚洲欧洲专区| 老牛国内精品亚洲成av人片| av亚洲一区二区三区| 午夜影院欧美| 日韩1区2区3区| 精品72久久久久中文字幕| 蜜臀国产一区| 蜜桃视频在线观看一区二区| 国产精品一区二区三区四区在线观看| 久久只有精品| 午夜国产欧美理论在线播放| 久久精品高清| 欧美色综合网| 成人国产精品| 亚洲精品1区2区| 国产麻豆一区| www.com.cn成人| 亚洲午夜国产成人| 亚洲狼人精品一区二区三区| 久久久国产精品网站| 99视频精品全国免费| 在线亚洲欧美| 国产丝袜一区| 激情视频一区二区三区| 日本亚洲不卡| 国产精品成久久久久| 怡红院精品视频在线观看极品| 日本不卡一二三区黄网| 久久精品亚洲| 亚洲精品人人| 国产一区二区三区91| 亚洲一区免费| 美女视频黄久久| 免费av一区二区三区四区| 国产精品久久久久久久久久齐齐| 国产综合亚洲精品一区二| 国产精品一区二区精品视频观看 | 日本少妇一区| 国产精品www.| 图片区亚洲欧美小说区| 久久97视频| 日韩一区免费| 免费视频最近日韩| 亚洲女同一区| 国产v综合v| 日韩成人免费| 国产精品一卡| 亚洲精品字幕| 欧美在线资源| 97se综合| 国产精品久久久久毛片大屁完整版| 国产精品av一区二区| 欧美日本不卡| 亚洲精品乱码日韩| 精品免费视频| 国产精品1区| 亚洲精品黄色| 成人精品天堂一区二区三区| 久久超级碰碰| 日韩精彩视频在线观看| 99在线精品免费视频九九视| 国产一区清纯| 久久狠狠婷婷| 国产精品精品| 国产成年精品| 精品国产亚洲一区二区在线观看| 日韩国产一区二| 99视频一区| 香蕉国产精品| 高清av不卡| 久久99影视| 国产精品亚洲人成在99www| 夜夜嗨一区二区| 欧美另类专区| 欧美一区二区三区高清视频| 精品中国亚洲| 麻豆网站免费在线观看| 久久亚洲国产精品尤物| 亚洲不卡视频| 日本成人在线网站| 蜜桃一区二区三区在线| 蜜臀av免费一区二区三区| 91精品精品| 欧美精品一区二区久久| 亚洲美洲欧洲综合国产一区| 欧美日韩国产v| 日韩福利一区| 久久狠狠婷婷| 亚洲国产综合在线看不卡| 视频一区中文| 影音先锋久久精品| 综合激情在线| 国产亚洲欧美日韩精品一区二区三区| 欧美日韩在线精品一区二区三区激情综合| 日韩欧美中文字幕在线视频| 日本精品久久| 国产欧美一区二区色老头| 国产精品久久久久久久久久白浆| 美女毛片一区二区三区四区最新中文字幕亚洲| 国产精品久久久免费| 久久免费精品| 久久久久国产一区二区| 狠狠爱成人网| 久久国产日韩欧美精品| 精品国产一区二区三区性色av| 日韩精品dvd| 亚洲欧美日韩国产一区二区| 亚洲色图国产| 精品午夜久久| 日韩亚洲国产欧美| 亚洲欧美久久精品| 卡一卡二国产精品| 啪啪国产精品| 狠狠爱成人网| 日韩 欧美一区二区三区| 中文字幕一区二区三区四区久久 | 婷婷激情一区| 首页亚洲欧美制服丝腿| 久久国内精品视频| 欧美成人精品三级网站| 免费美女久久99| 国产精品久久久网站| 99精品在线免费在线观看| 少妇精品久久久一区二区| 精品美女视频| 国产精品丝袜xxxxxxx| 午夜一级久久| 精品午夜久久| 一区二区三区四区日韩| 国产成年精品| 日本在线一区二区三区| 亚洲精品一级二级| 日本不卡在线视频| 99精品电影| 国产精品日本一区二区不卡视频| 日本免费一区二区三区四区| 婷婷视频一区二区三区| 欧美日韩中文字幕一区二区三区| 日韩高清一区二区| 欧美精品一区二区久久| 麻豆精品在线播放| 黄色精品网站| 你懂的亚洲视频| 免费日韩一区二区| 高清av一区| 91精品国产一区二区在线观看| 激情视频网站在线播放色 | 日韩在线电影| 99久久99久久精品国产片果冰| 国产精品一页| 男人操女人的视频在线观看欧美| 日韩一区二区三区免费播放| 88久久精品| 最新日韩欧美| 在线精品亚洲欧美日韩国产| 日本欧美一区| 日韩一区二区久久| 久久青草久久| 欧美久久天堂| 久久三级中文| 91麻豆精品| 免费精品视频最新在线| 日韩av首页| 极品av在线| 国产一区二区三区四区大秀| 日本午夜精品视频在线观看| 男女精品网站| 影院欧美亚洲| 蜜桃av在线播放| 国产成人久久| 18国产精品| 亚洲精品成人一区| 蜜臀精品久久久久久蜜臀| 不卡av一区二区| 久久国产亚洲| 欧美天堂视频| 国产精品字幕| 日韩av在线播放网址| 免费一级欧美片在线观看网站| 国产亚洲精aa在线看| 综合视频一区| 美国欧美日韩国产在线播放| 亚洲少妇在线| 欧美不卡视频|