当前位置:懂科普 >

IT科技

> 如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录

目录方法1:查询重复记录1、查询重复记录。2、从名为"Names"的列中查询重复记录。3、从其他列中查询重复记录。方法2:删除单个重复记录1、Sele2、删除所有有重复名称的行。3、重新输入没有重复记录的行。4、查看新列表。方法3:删除多个重复记录1、选择要删除的RowID。2、删除重复记录。3、检查重复记录。方法4:删除包含指定列的行1、选择行。2、通过查询每行的列来删除重复行。3、查看重复记录。当你使用Oracle时,可能会发现有重复记录。你可以通过查询重复行、使用其RowID,或者行地址来删除它们。在开始之前,你应该创建一个备份表,以防在删除记录之后需要引用它们。

方法1:查询重复记录

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第2张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第3张

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

select column_name, count(column_name) from table group by column_namehaving count (column_name) > 1;

方法2:删除单个重复记录

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第4张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第5张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第6张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第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:删除多个重复记录

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第8张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第9张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第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:删除包含指定列的行

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第11张

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

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第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);"来删除重复记录。

如何删除Oracle中的重复记录 4种方法来删除Oracle中的重复记录 第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 重复记录
  • 文章版权属于文章作者所有,转载请注明 https://dongkepu.com/itkeji/lqmdm4.html