While working in Oracle, you can find duplicates on some records. You can remove duplicate rows by identifying them and using the corresponding RowID alias row address. Before starting, create a backup table in case you need a reference after the record is deleted.
Step
Method 1 of 4: Identifying Duplicates
data:image/s3,"s3://crabby-images/7c835/7c835b1a856720a41774e2387c4d85c5f646d52e" alt="Delete Duplicate Records in Oracle Step 1 Delete Duplicate Records in Oracle Step 1"
Step 1. Identify duplicates
In this example, we identify the duplicate "Alan". Make sure the records to be deleted are indeed duplicates by entering the SQL below.
data:image/s3,"s3://crabby-images/84f35/84f35c51085b3402b6a69dff9307370993896539" alt="Delete Duplicate Records in Oracle Step 2 Delete Duplicate Records in Oracle Step 2"
Step 2. Identify from the column titled "Name"
In case the column has the title "Name", you need to replace " column_name " with Name.
data:image/s3,"s3://crabby-images/5e268/5e268982b942583b3a8f427ca999a84d13638858" alt="Delete Duplicate Records in Oracle Step 3 Delete Duplicate Records in Oracle Step 3"
Step 3. Identify from other columns
If you are trying to identify duplicates from different columns, for example Alan's age instead of his name, enter “Age” in place of " column_name " and so on.
select column_name, count(column_name) from table group by column_name having count (column_name) > 1;
Method 2 of 4: Removing Single Duplicates
data:image/s3,"s3://crabby-images/f1771/f1771df395b1ce16f8738068d60dcab7b4fc1336" alt="Delete Duplicate Records in Oracle Step 4 Delete Duplicate Records in Oracle Step 4"
Step 1. Select " name from names"
After "SQL" (short for Standard Query Language), enter " select name from names ".
data:image/s3,"s3://crabby-images/40d4e/40d4e4f4a2001be8b07ecb3218cee0511f6a08c8" alt="Delete Duplicate Records in Oracle Step 5 Delete Duplicate Records in Oracle Step 5"
Step 2. Delete all rows with duplicate names
After "SQL", enter " delete from names where name ='Alan';." It should be noted that capitalization is important here so that this step can delete all the lines named "Alan". After "SQL", enter "commit"
data:image/s3,"s3://crabby-images/895e7/895e787e701aec7bead8abee58f5decffc6ca94c" alt="Delete Duplicate Records in Oracle Step 6 Delete Duplicate Records in Oracle Step 6"
Step 3. Re-enter rows without duplicates
Now that you've deleted all the rows and replaced them with "Alan", fill one back in by entering " insert into name values ('Alan');." After "SQL", enter " commit " to create a new line.
data:image/s3,"s3://crabby-images/aa605/aa605a2897fd17d55c467df7ca71bd9524795f02" alt="Delete Duplicate Records in Oracle Step 7 Delete Duplicate Records in Oracle Step 7"
Step 4. View the new list
After completing the steps above, you can check to make sure there are no more duplicate records by entering " select * from names ".
SQL > select name from names; NAME ------------------------------ Alan Citra Tomi Alan Baris selected. SQL > delete from names where name='Alan'; The line is deleted. SQL > commits; \Commit complete. SQL > insert into names values('Alan'); row created. SQL > commits; Commit complete. SQL > select * from names; NAME ------------------------------ Alan Citra Tomi rows selected.
Method 3 of 4: Removing Multiple Duplicates
data:image/s3,"s3://crabby-images/86e64/86e6406988eed7f475943a1a1cba209641908a32" alt="Delete Duplicate Records in Oracle Step 8 Delete Duplicate Records in Oracle Step 8"
Step 1. Select the RowID you want to delete
After "SQL", enter " select rowid, name from names;."
data:image/s3,"s3://crabby-images/b5058/b5058441359d728d97f5582f873f79d7ecf5e7eb" alt="Delete Duplicate Records in Oracle Step 9 Delete Duplicate Records in Oracle Step 9"
Step 2. Remove duplicates
After "SQL", enter " delete from names a where rowid > (select min(rowid) from names b where b.name=a.name);" to remove duplicates.
data:image/s3,"s3://crabby-images/79ce5/79ce555c8afcb0651b2b4cf5ca12d594d19f057d" alt="Delete Duplicate Records in Oracle Step 10 Delete Duplicate Records in Oracle Step 10"
Step 3. Check for duplicates
After completing the above steps, check for duplicates by entering " select rowid, name from names;" then "commit".
SQL > select rowid, name from names; ROWID NAME ------------------ ------------------------------ AABJnsAAGAAAdfOAAA Alan AABJnsAAGAAAdfOAAB Alan AABJnsAAGAAAdfOAAC Carrie AABJnsAAGAAAdfOAAD Tom AABJnsAAGAAAdfOAAF Alan rows selected. SQL > delete from names a where rowid > (select min(rowid) from names b where b.name=a.name); rows deleted. SQL > select rowid, name from names; ROWID NAME ------------------ ------------------------------ AABJnsAAGAAAdfOAAA Alan AABJnsAAGAAAdfOAAC Carrie AABJnsAAGAAAdfOAAD Tom rows selected. SQL > commits; Commit complete.
Method 4 of 4: Deleting Rows by Columns
data:image/s3,"s3://crabby-images/d2d2b/d2d2b21b462f62af8ea6750d216d5211851d56cb" alt="Delete Duplicate Records in Oracle Step 11 Delete Duplicate Records in Oracle Step 11"
Step 1. Select the row
After "SQL", enter " select * from names;" to be able to see the line.
data:image/s3,"s3://crabby-images/5a9fd/5a9fd1dfc7725ab3a818510447353570bff19888" alt="Delete Duplicate Records in Oracle Step 12 Delete Duplicate Records in Oracle Step 12"
Step 2. Remove duplicate rows by identifying their columns
After "SQL'" enter " delete from names a where rowid > (select min(rowid) from names b where b.name=a.name and b.age=a.age);" to remove duplicate records.
data:image/s3,"s3://crabby-images/5b04f/5b04f1586338110d779df2620f20bb30e9df9124" alt="Delete Duplicate Records in Oracle Step 13 Delete Duplicate Records in Oracle Step 13"
Step 3. Check for duplicates
Once you have completed the steps above, enter " select * from names;" then " commit " to see if the duplicates have actually been removed.
SQL > select * from names; NAME AGE ------------------------------ ---------- Alan 50 Citra 51 Tomi 52 Alan 50 rows selected. SQL > delete from names a where rowid > (select min(rowid) from names b where b.name=a.name and b.age=a.age); row deleted. SQL > select * from names; NAME AGE ------------------------------ ---------- Alan 50 Citra 51 Tomi 52 rows selected. SQL > commits; Commit complete.
Warning
-
Create a duplicate table in your login so that it can be used as a content reference when no data has been deleted (in case you have any questions).
SQL > create table alan.names_backup as select * from names; Table created.