怎么样删除Oracle中的重复记录 应该怎么做?

来源:互联网
责任编辑:鲁能
 综合 
字体:

探索这篇文章查询重复记录删除单个重复记录删除多个重复记录删除包含指定列的行显示其它1点...显示较少内容...相关文章参考

当你使用Oracle时,可能会发现有重复记录。你可以通过查询重复行、使用其RowID,或者行地址来删除它们。在开始之前,你应该创建一个备份表,以防在删除记录之后需要引用它们。

1查询重复记录

以Delete Duplicate Records in Oracle Step 1为标题的图片

1查询重复记录。在本例中,查询示例重复记录“Alan”。通过输入下面的SQL,确保要删除的记录确实是重复的。

以Delete Duplicate Records in Oracle Step 2为标题的图片

2从名为“Names”的列中查询重复记录。在本例中,列名为“Names”,你要用Names来替换“column_name”。

以Delete Duplicate Records in Oracle Step 3为标题的图片

3从其他列中查询重复记录。如果你尝试从其他列中查询重复记录,比如Alan的年龄,而不是他的名字,那么你需要在“column_name”这个地方输入“Ages”,以此类推。

SELECT column_name, COUNT(column_name) FROM TABLE GROUP BY column_nameHAVING COUNT (column_name) > 1;

2删除单个重复记录

以Delete Duplicate Records in Oracle Step 4为标题的图片

1Select "name from names."在“SQL(结构化查询语言)”后输入“select name from names.”

以Delete Duplicate Records in Oracle Step 5为标题的图片

2删除所有有重复名称的行。在“SQL,”后输入“delete from names where name='Alan';”。注意,字母大写很重要,这样就可以删除所有名为“Alan”的行。在“SQL”后输入“commit”。[1]

以Delete Duplicate Records in Oracle Step 6为标题的图片

3重新输入没有重复记录的行。现在已经删除了所有名为“Alan”的行,可以通过输入“insert into name values ('Alan');”来插入一条记录。在“SQL”后输入“commit”,创建新行。

以Delete Duplicate Records in Oracle Step 7为标题的图片

4查看新列表。当你完成上述步骤后,通过输入“select * from names”检查一下,确保没有重复记录。

SQL > SELECT name FROM names;NAME------------------------------AlanCarrieTomAlanROWS selected.SQL > DELETE FROM names WHERE name='Alan';ROWS deleted.SQL > COMMIT;COMMIT complete.SQL > INSERT INTO names VALUES ('Alan');ROW created.SQL > COMMIT;COMMIT complete.SQL > SELECT * FROM names;NAME------------------------------AlanCarrieTomROWS selected.

3删除多个重复记录

以Delete Duplicate Records in Oracle Step 8为标题的图片

1选择要删除的RowID。在“SQL”后输入“select rowid, name from names;”。

以Delete Duplicate Records in Oracle Step 9为标题的图片

2删除重复记录。在“SQL”后输入“delete from names a where rowid > (select min(rowid) from names b where b.name=a.name);”来删除重复记录。[2]

以Delete Duplicate Records in Oracle Step 10为标题的图片

3检查重复记录。完成上述操作后,输入“select rowid,name from names;”,然后输入“commit”,检查是否仍然存在重复记录。

SQL > SELECT ROWID,name FROM names;ROWID    NAME------------------ ------------------------------AABJnsAAGAAAdfOAAA AlanAABJnsAAGAAAdfOAAB AlanAABJnsAAGAAAdfOAAC CarrieAABJnsAAGAAAdfOAAD TomAABJnsAAGAAAdfOAAF AlanROWS selected.SQL > DELETE FROM names aWHERE ROWID > (SELECT MIN(ROWID) FROM names bWHERE b.name=a.name);ROWS deleted.SQL > SELECT ROWID,name FROM names;ROWID    NAME------------------ ------------------------------AABJnsAAGAAAdfOAAA AlanAABJnsAAGAAAdfOAAC CarrieAABJnsAAGAAAdfOAAD TomROWS selected.SQL > COMMIT;COMMIT complete.

4删除包含指定列的行

以Delete Duplicate Records in Oracle Step 11为标题的图片

1选择行。在“SQL”后输入“select * from names;”来查看行。

以Delete Duplicate Records in Oracle Step 12为标题的图片

2通过查询每行的列来删除重复行。在“SQL”后输入“delete from names a where rowid > (select min(rowid) from names b where b.name=a.name and b.age=a.age);”来删除重复记录。[3]

以Delete Duplicate Records in Oracle Step 13为标题的图片

3查看重复记录。完成上述步骤后,输入“select * from names;”,然后输入“commit”,以检查是否成功删除了重复记录。

SQL > SELECT * FROM names;NAME         AGE------------------------------ ----------Alan         50Carrie         51Tom         52Alan         50ROWS selected.SQL > DELETE FROM names aWHERE ROWID > (SELECT MIN(ROWID) FROM names bWHERE b.name=a.nameAND b.age=a.age);ROW deleted.SQL > SELECT * FROM names;NAME         AGE------------------------------ ----------Alan         50Carrie         51Tom         52ROWS selected.SQL > COMMIT;COMMIT complete.

警告

登录自己的账号后创建一个备份表,这样可以用来显示进行任何删除之前的内容(防止出现任何问题)。

SQL > CREATE TABLE alan.names_backup AS SELECT * FROM names;TABLE created.

根据您访问的内容,您可能还对以下内容感兴趣,希望对您有帮助:

oracle中删除两条相同记录中的一条,该怎么操作?

答:delete from dept where rowid not in (select min(rowid) from dept group by deptno , dname ,loc) 这样可以保证所有的重复数据仅保留一条,其余的删除

oracle删除重复的行怎么删啊

答:假设你表名为a 唯一的字段名为 xxxx, 按如下方式 delete a where a.rowid not in( select min(a.rowid) from a group by a.xxxx) 每个表都有一个rowid列

oracle数据库怎么删除重复数据只留一个?

答:查询及删除重复记录的SQL语句 1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 ; select * from 表 where Id in (select Id from 表 group byId having count(Id) > 1) 2、删除表中多余的重复记录,重复记录是根据单个字段(Id...

oracle数据库怎么删除重复数据只留一个?

答:直接执行该sql就可以了: delete from dj_clr a where (a.dj_mc,a.dj_dh) in (select dj_mc,dj_dh from dj_clr group by dj_mc,dj_dh having count(*) > 1) and rowid not in (select min(rowid) from dj_clr group by dj_mc,dj_dh having count...

Oracle数据库重复数据删除的几种方法

答:用这种效率最高的就可以 比如,某个表要按照id和name重复,就算重复数据 delete from 表名 where rowid not in (select min(rowid) from 表名 group by id,name);commit;如果以id,name和grade重复算作重复数据 delete from 表名 where rowid no...

Oracle中怎么去掉重复的行

答:Oracle中去掉重复的行,用以下方法: 如test表中有如下数据: 现要去掉name中重复的数据,可用如下语句将多余数据删除: delete from test where id not in (select max(id) from test group by name);执行后结果:

oracle中怎么删除数据中重复的字段,只保留重复数...

答:oracle中在一张表中某个字段下面有重复记录,有很多方法,但是有一个方法,是比较"高效"的,如下语句: SELECT data_guid FROM adam_entity_datas a WHERE a.rowid > (SELECT MIN(b.rowid) FROM adam_entity_datas b WHERE b.data_guid = a.data...

oracle查询出来的数据怎么消除重复数据?

答:Oracle数据库重复的数据一般有两种去重方法,一、完全重复数据去重;二、部分字段数据重复去重。 一、完全重复数据去重方法 对于表中完全重复数据去重,可以采用以下SQL语句。 Code CREATETABLE"#temp"AS (SELECTDISTINCT * FROM 表名);--创建临...

oracle数据库中如何用sql语句查出重复字段以及如何...

答:查询可用group by语句,删除则用delete语句。 1、创建测试表,插入测试数据: create table test(id int,name varchar2(20));insert into test values (1,'张三');insert into test values (1,'张三');insert into test values (2,'李四');inser...

如何查找Oracle数据库中的重复记录

答:select data_guid from adam_entity_datas where data_guid in (select data_guid from adam_entity_datas group by data_guid having count(*) > 1)


www.book1234.com true http://www.book1234.com/10/4336/108655.html report 82212 怎么样删除Oracle中的重复记录应该怎么做?,探索这篇文章查询重复记录删除单个重复记录删除多个重复记录删除包含指定列的行显示其它1点...显示较少内容...相关文章参考当你使用Oracle时,可能会发现有重复记录。你可以通过查询重复行、使用其RowID,或者行地址来删除它们。在开始之前,你应该创...
娱乐时尚
科技资讯
历史文化
真视界
旅游美食
精彩图文
我爱我车
母婴健康
关于本站 | 广告服务 | 手机版 | 商务合作 | 免责申明 | 招聘信息 | 联系我们
Copyright © 2004-2018 book1234.com All Rights Reserved. 布客网 版权所有
京ICP备10044368号-1 京公网安备11010802011102号
教育考试: 学历财经建筑 医药公考资格外语电脑作文招聘中小学留学 文档 移民 文库专栏23问答中心z资讯z资讯1资讯涨资讯涨资讯1资讯问答图书馆知识IT编程数码信息解决方案信息中心IT科技问答新闻中心软件教室设计大全网络相关英语学习开发编程考试中心参考范文管理文库营销中心站长之家IT信息中心商学院数码大全硬件DIY企业服务网吧在线百科硬件知识手机平板汽车游戏家电精彩摄影现代家居IT女人经验健康养生猎奇创业攻略教育学习历史时尚潮流最近更新涨知识