SQL(二)删除字段名相同的数据并保留其中一条

例子

相同的字段(caiName)有好几条数据,表名是Answer

步骤

一、取出想同名字的id和caiName

sql语句:select caiName,id from Answer where caiName = "菠萝炒饭";

图片结果

二、取出其中id最小的一条记录

sql语句:select id from Answer where caiName = "菠萝炒饭" group by caiName;

这里写图片描述

三、进行拼装删除

sql语句:delete from Answer where id in(**select a.id from(**select id from Answer a where a.caiName = "菠萝炒饭"**)a**) and id not in (select b.id from (select `id` from Answer b where b.caiName = "菠萝炒饭" group by caiName)b);

这里写图片描述

四、验证结果

sql语句:select caiName,id from Answer where caiName = "菠萝炒饭";

这里写图片描述

注意点

在第三步的** **部分是需要填写的不填写的话就会报错
You can't specify target table '表名' for update in FROM clause
所以要加上 加粗的部分

解决办法
借鉴别人的解决办法有解释

只在命令行测试成功 只适合mysql

这里有除mysql之外的解决办法

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值