当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:22:00  来源:本站整理

在SQL中删除反复记录(多种办法)[MSSQL防范]

赞助商链接



  本文“在SQL中删除反复记录(多种办法)[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
?? 学习sql有一段时间了,发目前我建了一个用来测试的表(没有建索引)中呈现了很多的反复记录.后来总结了一些删除反复记录的办法,在Oracle中,可以通过唯一rowid实现删除反复记录;还可以建暂时表来实现...这个只提到此中的几种简单实用的办法,但愿可以和大家分享(以表employee为例).

SQL> desc employee

?Name????????????????????????????????????? Null???? Type
?----------------------------------------- -------- ------------------

emp_id??????????????????????????????????????????????? NUMBER(10)
emp_name?????????????????????????????????????????? VARCHAR2(20)

salary???????????????????????????????????????????????? ?NUMBER(10,2)

?

?

可以通过下面的语句查询反复的记录:

SQL> select * from employee;

?

??? EMP_ID EMP_NAME????????? ????????????????????????SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon??????????????????? ?????????????????????20000

???????? 2 semon???????????????????????????????????????? 20000

???????? 3 xyz?????????????????????????????????????????? 30000

???????? 2 semon???????????????????????????????????????? 20000

?


SQL>
select distinct * from employee;

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon???????????????????????????????????????? 20000

??? ?????3 xyz???????????????????????????????????????????? 30000

SQL>? select * from employee group by emp_id,emp_name,salary having count (*)>1

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon????????????????????????????????????????? 20000


SQL>
select * from employee e1

where rowid in (select max(rowid) from employe e2
?
where e1.emp_id=e2.emp_id and

? e1.emp_name=e2.emp_name and e1.salary=e2.salary);

?

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 3 xyz????? ?????????????????????????????????????? 30000

???????? 2 semon???????????????????????????????????????? 20000

?

?

2. 删除的几种办法:

?

1)通过成立暂时表来实现

SQL>create table temp_emp as (select distinct * from employee)?

SQL> truncate table employee; (清空employee表的数据)

SQL> insert into employee select * from temp_emp; ?(再将暂时表里的内容插回来)

?

( 2)通过唯一rowid实现删除反复记录.Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid肯定了每条记录是在Oracle中的哪一个数据文件、块、行上.在反复的记录中,大概全部列的内容都相同,但rowid不会相同,所以只要肯定出反复记录中那些具有最大或最小rowid的便可以了,别的全部删除.

SQL>delete from employee e2 where rowid not in (
???????
select max(e1.rowid) from employee e1 where

??????? e1.emp_id=e2.emp_id and e1.emp_name=e2.emp_name and e1.salary=e2.salary);--这里用min(rowid)也可以.

?

SQL>delete from employee e2 where rowid <(
???????
select max(e1.rowid) from employee e1 where
??????? e1.emp_id
=e2.emp_id and e1.emp_name=e2.emp_name and

????????????????? e1.salary=e2.salary);

?

3)也是通过rowid,但效率更高.

SQL>delete from employee where rowid not in (
???????
select max(t1.rowid) from employee t1 group by

???????? t1.emp_id,t1.emp_name,t1.salary);--这里用min(rowid)也可以.

?

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 3 xyz???? ??????????????????????????????????????? 30000

???????? 2 semon???????????????????????????????????????? 20000

?

?

?

SQL> desc employee

?Name????????????????????????????????????? Null???? Type
?----------------------------------------- -------- ------------------

emp_id??????????????????????????????????????????????? NUMBER(10)
emp_name?????????????????????????????????????????? VARCHAR2(20)

salary???????????????????????????????????????????????? ?NUMBER(10,2)

?

?

可以通过下面的语句查询反复的记录:

SQL> select * from employee;

?

??? EMP_ID EMP_NAME????????? ????????????????????????SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon??????????????????? ?????????????????????20000

???????? 2 semon???????????????????????????????????????? 20000

???????? 3 xyz?????????????????????????????????????????? 30000

???????? 2 semon???????????????????????????????????????? 20000

?


SQL>
select distinct * from employee;

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon???????????????????????????????????????? 20000

??? ?????3 xyz???????????????????????????????????????????? 30000

SQL>? select * from employee group by emp_id,emp_name,salary having count (*)>1

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 2 semon????????????????????????????????????????? 20000


SQL>
select * from employee e1

where rowid in (select max(rowid) from employe e2
?
where e1.emp_id=e2.emp_id and

? e1.emp_name=e2.emp_name and e1.salary=e2.salary);

?

??? EMP_ID EMP_NAME???????????????????????????????????? SALARY

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

???????? 1 sunshine????????????????????????????????????? 10000

???????? 3 xyz????? ?????????????????????????????????????? 30000

???????? 2 semon???????????????????????????????????????? 20000

本新闻共2页,当前在第1页??1??2
  以上是“在SQL中删除反复记录(多种办法)[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 在SQL Server中利用SQL语句查询一个存储历程被别的全部的存储历程引用的存储历程名
  • 在SQL Server 2005中成立数据库镜像的步骤及事项
  • 在SQL2005 轻松配置SSIS包
  • 在SQL中删除反复记录(多种办法)
  • 在SQL Server的存储历程中调用Com组件
  • 在SQLServer中保存和输出图片
  • 在SQLSERVER里写了一个Split函数
  • 在SQL Server中快速删除反复记录
  • 在SQL Server中保存和输出图片
  • 如安在SQL Server数据库差别版本中存储数据
  • <b>在SQL Server中实现循环每一行做一定的操作</b>
  • 在SQL Server数据库中成批导入数据四种办法
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .