设为首页 加入收藏

TOP

Oracle数据库删除表中重复记录的常见方法
2014-11-24 07:39:06 来源: 作者: 【 】 浏览:2
Tags:Oracle 数据库 删除 重复 记录 常见 方法

方法一:


delete from tb_channel a where a.rowid in

(select max(b.rowid) from tb_channle b

where a.policyno=b.policyno and a.classcode=b.classcode);


――这一办法在数据记录超过10万时一般都会变得很慢。


方法二:


--建立临时表,--清空原表,--插回原表,如下例:

create table temp_emp as (select distinct * from employee) ;

truncate table employee;

insert into employee select * from temp_emp;


――这一办法适用于较大的表的情况。因为是块操作,对应于大表效率会好很多


方法三:


--建立新表,--去重复放入,--删除原表,如下例:

select distinct * into new_table from old_table

order by 主 键

drop table old_table

exec sp_rename new_table,old_table;


――这一办法适用于较大的表的情况。因为是块操作,对应于大表效率会好很多

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Oracle数据导入导出 下一篇oracle job用法

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C++ Lambda表达式保 (2025-12-26 05:49:45)
·C++ Lambda表达式的 (2025-12-26 05:49:42)
·深入浅出 C++ Lambda (2025-12-26 05:49:40)
·C语言指针从入门到基 (2025-12-26 05:21:36)
·【C语言指针初阶】C (2025-12-26 05:21:33)