方法一:
通过唯一rowid实现删除重复记录.在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid确定了每条记录是在Oracle中的哪一个数据文件、块、行上。在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中那些具有最大或最小rowid的就可以了,其余全部删除。
SQL> delete from employee e2 where e2.rowid not in(
select max(e1.rowid) from employee e1 where e1.emp_id=e2.emp_id and e1.emp_name=e2.emp_name and e1.salary=e2.salary);
——这一办法在数据记录超过10万时一般都会变得很慢。
方法二:
也是通过rowid,但效率更高。
SQL> delete from employee where rowid not in(
select max(t1.rowid) from employee t1 group by t1.emp_id, t1.emp_name, t1.salary);
方法三:
通过建立临时表来实现 --建立临时表,--清空原表,--插回原表,如下例:
SQL>create table temp_emp as (select distinct * from employee)
SQL> truncate table employee;(清空employee表的数据)
SQL>insert into employee select * from temp_emp; (再将临时表里的内容插回来)
——这一办法适用于较大的表的情况。因为是块操作,对应于大表效率会好很多。