公告:欢迎访问,查看更多资源请点我^.^!            点我关闭广告
sql删除重复数据
2019-06-26 22:56:09
284人阅读
评论(0)
分类:数据库

网上查看了好多删除重复数据的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等关联语法!不知道大家有什么意见或者建议呢?

分享一下:
赞一下(4)
博主资料
博主头像
zc521106
文章:34
浏览:19899
文章分类
Java(12)
NoSql(112)
数据库(12)
前端(12)
阅读排行
Java基础知识
(12)
NoSql应用
(112)
数据库Oracle语法
(12)
前端常用工具类
(12)
java web项目
(12)
linux安装mysql
(12)
评论区
这篇文章怎么样?写点评论吧!
姓名:
邮箱:
有回复时通知我:
发表
回复【10.20.30.32】:
暂无评论,快抢沙发!
* 以上用户言论只代表其个人观点,不代表iBlog网站的观点或立场,如有任何疑问请随时联系管理员...