zoukankan      html  css  js  c++  java
  • 用SQL语句删除数据库重复数据,只保留一条有效数据

    在实际开发中,可能会遇到数据库多条数据重复了,此时我们需要删除重复数据,只保留一条有效数据,用SQL语句怎么实现呢,下面我们模拟一下:

    1.准备重复数据:
    在这里插入图片描述
    2.过滤出存在重复数据的信息:

    SQL语句:

    SELECT
    	dname 
    FROM
    	dept 
    GROUP BY
    	dname 
    HAVING
    	count( dname ) >1
    

    数据库筛选结果:
    在这里插入图片描述
    3.从重复数据中筛选出一条需要保存的数据:

    SQL语句:

    SELECT
    	min( deptno ) -- max( deptno )
    	
    FROM
    	dept 
    GROUP BY
    	dname 
    HAVING
    	count( dname ) >1
    

    这里使用数据库的MIN或者MAX函数筛选出一条需要保存数据即可。

    数据库筛选结果:
    在这里插入图片描述
    4.删除重复数据,即从重复的数据中,删除掉需要保留数据之外的所有信息:

    SQL:

    DELETE 
    FROM
    	dept 
    WHERE
    	dname IN ( SELECT dname FROM dept GROUP BY dname HAVING count( dname ) > 1 ) -- 过滤出重复的dname
    	AND deptno NOT IN ( SELECT min( deptno ) AS deptno FROM dept GROUP BY dname HAVING count( dname ) > 1 ) -- 过滤出不在需要保留的id之外的所有id
    	
    

    如果是oracle数据库,上面的SQL语句可以正常执行,可是换成mysql数据库,SQL语句执行会报错:

    1093 - You can't specify target table 'dept' for update in FROM clause
    

    含义:不能在同一表中查询的数据作为同一表的更新数据。

    适用于mysql数据库的SQL:

    DELETE 
    FROM
    	dept 
    WHERE
    	dname IN ( SELECT * FROM ( SELECT dname FROM dept GROUP BY dname HAVING count( dname ) > 1 ) a ) 
    	AND deptno NOT IN ( SELECT * FROM ( SELECT min( deptno ) AS deptno FROM dept GROUP BY dname HAVING count( dname ) > 1 ) b )
    

    数据库最后数据:
    在这里插入图片描述
    到这里,删除重复数据成功!

    一颗安安静静的小韭菜。文中如果有什么错误,欢迎指出。
  • 相关阅读:
    全局变量 static变量
    【Qt学习笔记】04_单选复选框
    【Qt学习笔记】03_特殊标签
    【Qt学习笔记】02_颜色对话框
    【Qt学习笔记】01_模态和非模态
    ThinkPad_E570 拆机
    VMware 共享文件夹
    【安装Flutter遇到的问题】 Android license status unknown
    VLC 外挂字幕乱码
    IE(IE6/IE7/IE8)支持HTML5标签--20150216
  • 原文地址:https://www.cnblogs.com/c-Ajing/p/13448349.html
Copyright © 2011-2022 走看看