删除反复行SQL实验简单举例

说明:实验按顺序进行。前后存在关联性。阅读时请注意。打开文件夹更便于查看。

构造实验环境:





SQL> select count(*) from emp;

  COUNT(*)

----------

        14

SQL> alter table EMP drop constraint PK_EMP CASCADE;

--删除主键约束

SQL> insert into EMP select * from EMP;

--向EMP表中插入反复行

SQL> commit;

SQL> select count(*) from emp;

  COUNT(*)

----------

        28

        

以下举例单字段删除反复行

例1:查询出反复记录(单字段)

SQL> select * from emp 

where empno in (select empno from emp group by empno having count 

(empno) > 1); 

--查找出emp表中多余的反复记录,反复记录是依据empno来判读





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30





28 rows selected.

例2:删除表中多余的反复记录,仅仅留有rowid最小的记录

SQL> delete from emp 

where empno in (select empno from emp group by empno having count 

(empno) > 1) 

and rowid not in (select min(rowid) from emp group by empno having count(empno 

)>1); 

--删除表中多余的反复记录。反复记录是依据单个字段empno来判读

--保留rowid最小的行记录信息

14 rows deleted.





SQL> select * from emp ;  --反复的行已经删除





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10





14 rows selected.













SQL> insert into emp select * from emp;





SQL> insert into emp values(8888,'HYL','DBA',7839,sysdate,2000,'',60);





1 row created.





SQL> commit;





Commit complete.





SQL> select * from emp;      





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      8888 HYL        DBA             7839 06-JUL-14       2000                    60





29 rows selected.









多字段下:

例3:查询表中反复的记录(多字段)

SQL> select * from emp a 

where (a.empno,a.deptno) in (select empno,deptno from emp group by empno,deptno having 

count(*) > 1); 





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30





28 rows selected.

例4:删除表中反复记录(多个字段),仅仅保留rowid最小的记录

SQL> delete from emp a 

where (a.empno,a.deptno) in (select empno,deptno from emp group by empno,deptno having 

count(*) > 1) 

and rowid not in (select min(rowid) from emp group by empno,deptno having count(*)>1); 





14 rows deleted.





SQL> select * from emp;





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      8888 HYL        DBA             7839 06-JUL-14       2000                    60





15 rows selected.













SQL> rollback 

  2  ;





Rollback complete.





SQL> select * from emp;





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      8888 HYL        DBA             7839 06-JUL-14       2000                    60





29 rows selected.

例5:查询表中多余的反复记录(多字段)。不包括rowid最小的记录

SQL> select * from emp a 

where (a.empno,a.deptno) in (select empno,deptno from emp group by empno,deptno having 

count(*) > 1) 

and rowid not in (select min(rowid) from emp group by empno,deptno having count(*)>1);





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30





14 rows selected.





SQL> commit;





Commit complete.





SQL> select * from emp;   --emp表实际数据





     EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      7844 TURNER     SALESMAN        7698 08-SEP-81       1500          0         30

      7902 FORD       ANALYST         7566 03-DEC-81       3000                    20

      7654 MARTIN     SALESMAN        7698 28-SEP-81       1250       1400         30

      7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20

      7369 SMITH      CLERK           7902 17-DEC-80        800                    20

      7566 JONES      MANAGER         7839 02-APR-81       2975                    20

      7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20

      7900 JAMES      CLERK           7698 03-DEC-81        950                    30

      7521 WARD       SALESMAN        7698 22-FEB-81       1250        500         30

      7698 BLAKE      MANAGER         7839 01-MAY-81       2850                    30

      7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10

      7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

      7499 ALLEN      SALESMAN        7698 20-FEB-81       1600        300         30

      7839 KING       PRESIDENT            17-NOV-81       5000                    10

      8888 HYL        DBA             7839 06-JUL-14       2000                    60





29 rows selected.

***********************************************声明************************************************

原创作品,出自 “深蓝的blog” 博客。欢迎转载。转载时请务必注明出处(http://blog.csdn.net/huangyanlong)。

表述有错误之处。请您留言。不胜感激。

提醒:点击文件夹。更有助于您的查看。

*****************************************************************************************************

删除反复行SQL举例的更多相关文章

  1. SQL Server删除重复行的6个方法

    SQL Server删除重复行是我们最常见的操作之一,下面就为您介绍六种适合不同情况的SQL Server删除重复行的方法,供您参考. 1.如果有ID字段,就是具有唯一性的字段 delect   ta ...

  2. SQL查找删除重复行

    本文讲述如何查找数据库里重复的行.这是初学者十分普遍遇到的问题.方法也很简单.这个问题还可以有其他演变,例如,如何查找“两字段重复的行”(#mysql IRC 频道问到的问题) 如何查找重复行 第一步 ...

  3. 【sql server】"已更新或删除的行值要么不能使该行成为唯一行,要么改变了多个行" 解决方案

    #事故现场: 1.在手动修改某表中数据是,出现如下错误提示:  已更新或删除的行值要么不能使该行成为唯一行,要么改变了多个行 2.表结构及数据: #解决方法: 1.原因分析:提示被删除的行不是唯一行, ...

  4. PreparedStatement執行sql語句

    import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import org ...

  5. Oracle删除重复行

    Oracle删除重复行 分类: ORACLE2010-12-12 17:10 423人阅读 评论(0) 收藏 举报 oracletabledeleteintegerinsert.net 查询及删除重复 ...

  6. SqlServer_删除重复行只保留一条记录

      前提:相同的数据重复往数据库写入,导致存在仅主键Id不同的重复数据,现在需要去除重复数据,仅保留重复数据中Id最大的一条   思路: 1.找出存在重复数据的记录,并取重复数据中最大的Id值 2.删 ...

  7. Linux之sed:删除某行以及替换

    sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换.删除.新增.选取等特定工作,下面先了解一下sed的用法sed命令行格式为:         sed ...

  8. REDHAT一总复习1 vim编辑器的使用 删除所有者列 删除指定行

    将文件/home/student/vimfile.txt 复制到server 上的/home/student/longlisting.txt . 根据下列要求,使用vim编辑器更改 /home/stu ...

  9. jquery Datatables 行数据删除、行上升、行下降功能演示

    Datatables 是一款jquery表格插件.它是一个高度灵活的工具,可以将任何HTML表格添加高级的交互功能. 官方网站:http://www.datatables.net Datatables ...

随机推荐

  1. Render 使用

    Page页面文件,重新Render 方法,目的是把页面的ViewState信息放在最后,利于页面展示速度和SEO优化. Render方法对于重新Html控件还是很好用的. private static ...

  2. 51Nod 1028 大数乘法 V2

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1028 分析: FFT/NTT板子题... 代码: NTT板子: #inc ...

  3. [TYVJ1930]编年史

    现在 applepi 手上有一本十分古老的编年史,这本史书记录了很多著名的历史事件.于是applepi 有了一个奇怪的想法……他想知道那些有名的历史事件都是在星期几发生的.现在轮到你了,你要帮助app ...

  4. 使用中科大源下载android源码

    我的系统时manjaro linux 最新版的,安装过了git和curl软件 一.如果没有安装的同学,请使用命令: pacman -S git curl 我这里安装了python3和python2,但 ...

  5. saltstack 模块学习之 state

     入口文件top.sls 三要素环境:通过file-roots指定目标主机:可以使用通配符*配置文件路径:路径分割符为. 比如a.mysql 表示在环境指定的路径下有个a目录,a目录下有个mysql. ...

  6. [转]在Storyboard中使用自定义的segue类型

    转自:http://my.oschina.net/u/728866/blog/92709 我们知道segue共有三种类型:push.modal以及custom.如下图:   很明显,这三种类型的作用分 ...

  7. JdbcTemplate模板使用

    1.添加模板的配置文件 在spring的配置文件中加入如下代码 <bean class="org.springframework.jdbc.core.JdbcTemplate" ...

  8. spring源码学习(一)

    Spring作为一个IOC容器,今天我们学习它作为web解析的地方,学习下webmvc包的代码.我们先看下web.xml文件 可以看到通过DispatcherServlet来实现页面的mapper处理 ...

  9. IIS配置支持apk文件下载

    写在前面 最近项目中涉及到移动端的东西,有一个功能是要下载apk文件,apk为安卓安装程序,但是iis默认是不支持该类型的文件下载的. 解决方案 找到该站点,并切换到功能视图 找到MIME类型,双击进 ...

  10. tiny4412 解决内核编译版本号问题

    内核版本: linux-3.5开发板: tiny4412作者:彭东林邮箱:pengdonglin137@163.com 问题: 由于我使用 git 管理内核代码,导致编译完成后内核版本变成了如下形式: ...