数据库保留最后一条重复的

有这么一个表,他可能但不一定会出现如下情况

id   name    pass  x
...
1    name1   123   1

...有n个name1重复的

n    name1   123   0
n+1  name2   321   1
n+2  name3   456   1
...


就是说,name这个字段有几个重复的,而x这个字段又不一样。
我现在要写这么一条SQL语句实现这么一个功能,
就是,在这些重复的记录里面,我只保留最后一条,前面的删掉。
怎么写呢?

 

SQL Server版:

delete t1 where [name] in (
select [name] from t1 group by [name] having count([name])>1)
and [id] not in
(select max([id]) from t1 group by [name] having count([name])>1)

MySQL 版:

由于MySQL不能对同一个表同时查询和删除,所以只能通过建立一个临时表的方法来解决

create table tmp_table
as select id from stu
where name in
(select name from stu group by name having count(name) > 1)
and id not in (select id from stu group by name having count(name) > 1);  

delete from stu where id in (select
id from tmp_table);  

drop table tmp_table;

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值