现在的位置: 首页 > 综合 > 正文

利用Oracle的row_number() over函数消除重复的记录

2018年05月06日 ⁄ 综合 ⁄ 共 506字 ⁄ 字号 评论关闭

1.select d.id,d.outer_code from  dict_depts_source d order by outer_code(查看重复数据)

查看重复数据

2.select d.id,d.outer_code,row_number() over(partition by outer_code order by outer_code) row_flag from  dict_depts_source d(标识重复数据)

标识重复数据

3.delete from dict_depts_source where id in(
select id from(select d.id,d.outer_code,row_number() over(partition by outer_code order by outer_code) row_flag from  dict_depts_source d)t
where t.row_flag > 1)(删除重复数据)

3.select d.id,d.outer_code,row_number() over(partition by outer_code order by outer_code) row_flag from  dict_depts_source d(检查删除效果)

检查重复数据

抱歉!评论已关闭.