sql删除重复数据

摘自:https://www.zhaochao.top/article/184

网上查看了好多删除重复数据的sql无非都是使用in或not in来组合封装,效率不是太好其实我们可以借助join来进行数据删除(查询)。

例如:
  表明score,sid为学生id,cid为课程id score为分数,status为数据状态(0删除 1可用);我们现在需要将score表中sid和cid都相同的数据去重,暂定留下id最大的;

查询:

select s.* from score s right join (select max(id) as id,cid,sid from score group by cid, sid having count(1) > 1) ss on (s.id != ss.id and s.cid=ss.cid and s.sid=ss.sid);

查询结果:


借鉴查询sql来删除或修改:

update score as s right join (select max(id) as id,cid,sid from score group by cid, sid having count(1) > 1) ss on (s.id != ss.id and s.cid=ss.cid and s.sid=ss.sid) set s.status = 0;
执行结果:

 

我存在的问题是 只知道查询的时候可以使用join 但是修改或删除操作的时候不知道可以使用join等关联语法!不知道大家有什么意见或者建议呢?

发布了125 篇原创文章 · 获赞 7 · 访问量 1万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览