删除重复记录的sql

当数据库表里有重复记录时怎么删除重复的那些数据呢?

当然前提是重复的定义:在数据库表,我们认为某个或者某几个字段相同,那就认为这条记录重复了。

如下表:

ROWIDDEP_IDDEP_NAMECOMPANY
AAARJ4AAEAAABeGAAA13                              人事部联想二部
AAARJ4AAEAAABeIAAA11                              研发部百度hahahaha
AAARJ4AAEAAABeIAAB12                              人事部联想一部


在这张表中,我认为dep_name重复的记录就是重复的。我想删除多余的人事部,只保留一个人事部。

sql如下:

select d.rowid from LSY_DEPARTMENT d /* delete from LSY_DEPARTMENT d*/
where d.rowid in
(
select rowid from LSY_DEPARTMENT c
where c.dep_name in
(
select a.dep_name from LSY_DEPARTMENT a
where 1=1
group by dep_name
having count(a.dep_name)>1
)
) and d.rowid not in
(
select min(t.rowid) from LSY_DEPARTMENT t
where 1=1
group by t.dep_name
having count(*)>1
)



ROWID
AAARJ4AAEAAABeIAAB


把上面第一行改成delete即可。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值