、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断

select*from
people

where peopleIdin
(select peopleIdfrom peoplegroupby
peopleIdhaving
)



、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录

deletefrom
people

where peopleIdin
(select peopleIdfrom peoplegroupby
peopleIdhaving
)

and rowidnotin
(selectmin(rowid)from peoplegroup
)



、查找表中多余的重复记录(多个字段)

select*from
vitae a

where (a.peopleId,a.seq)in
(select peopleId,seqfrom vitaegroup
)



、删除表中多余的重复记录(多个字段),只留有rowid最小的记录

deletefrom
vitae a

where (a.peopleId,a.seq)in
(select peopleId,seqfrom vitaegroup
)

and rowidnotin
(selectmin(rowid)from vitae
group
)



、查找表中多余的重复记录(多个字段),不包含rowid最小的记录

select*from
vitae a

where (a.peopleId,a.seq)in
(select peopleId,seqfrom vitaegroup
)

and rowidnotin
(selectmin(rowid)from vitae
group
)

(二)

比方说

在A表中存在一个字段“name”,

而且不同记录之间的“name”值有可能会相同,

现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;

Select Name,Count(*)From
A Group


如果还查性别也相同大则如下:

Select Name,sex,Count(*)From
A Group


(三)

方法一

declare@maxinteger,@idinteger

declare
cur_rows cursor localforselect 主字段,count(*)from
表名 group


open
cur_rows

fetch cur_rowsinto@id,@max



begin

select@max=


setrowcount@max

deletefrom
表名 where 主字段=@id

fetch
cur_rows into@id,@max

end

close
cur_rows





  方法二



  有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。



  、对于第一种重复,比较容易解决,使用

selectdistinct*
from tableName



  就可以得到无重复记录的结果集。



  如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除

selectdistinct*
into #Tmpfrom tableName

droptable
tableName

select*into
tableNamefrom #Tmp

droptable
#Tmp



  发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。



  、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下



  假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集

)as
autoID, *
into #Tmpfrom tableName

selectmin(autoID)as
autoID into #Tmp2from #Tmp
groupby Name,autoID

select*from
#Tmpwhere autoIDin(select autoIDfrom
#tmp2)



  最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)



(四)查询重复

select*from
tablenamewhere idin (

select idfrom
tablename

group
by id

having
count(id)>


)

sql记录去重(SQL查询或者删除表中重复记录)的更多相关文章

  1. MSSQL sql server 2005/2008 row_number()函数应用之–删除表中重复记录,只保留一条不重复数据

    转自:http://www.maomao365.com/?p=4942 下文主要讲述:重复数据只获取一条的方法 row_number函数在数据库中的功能是为每一行 按照一定的规则生成一个编号,我们常常 ...

  2. 查询和删除表中重复数据sql语句

      1.查询表中重复数据.select * from peoplewhere peopleId in (select   peopleId   from   people   group   by   ...

  3. SqlServer删除表中重复记录

    重复记录:有两个意义上的重复记录 一是完全重复的记录,也即所有字段均重复的记录: 二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略. 1.对于第一种重复,比较容易 ...

  4. mysql 查询及 删除表中重复数据

    CREATE TABLE `test` ( `id` INT(20) NOT NULL AUTO_INCREMENT, `name` VARCHAR(20) NULL DEFAULT NULL, `a ...

  5. oracle 查询及删除表中重复数据

    create table test1( id number, name varchar2(20) ); ,'jack'); ,'jack'); ,'peter'); ,'red'); insert i ...

  6. Oracle通过ROWID删除表中重复记录

    -- 1 通过ROWID删除T1表里重复的记录    SELECT ROWID,A,B--DELETE FROM  T1WHERE ROWID IN (  SELECT RD  FROM  (     ...

  7. sql删除表中重复记录只保留一条记录

    最终代码 update T_Fee set gzl_dfg_op = 'delete' where MetReadRecordID in ( select MetReadRecordID from T ...

  8. 使用oracle删除表中重复记录

    (1)使用用rowid方法 查询重复数据:select * from person a where rowid !=(select max(rowid) from person b where a.c ...

  9. Sql Server删除数据表中重复记录 三种方法

    本文介绍了Sql Server数据库中删除数据表中重复记录的方法. [项目]数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除![分析]1 ...

随机推荐

  1. 2.Cocos2dx 3.2中的重力系统Box2D

     1 添加Box2D相关的库 步骤1:右击项目所在的解决方案à添加->现有项目àE:\Installed\cocos2d-x-3.2\cocos2d-x-3.2\external\Box2D ...

  2. 关于Android PullTorefreshScrollview回到顶部实例

    列表滑动下面显示按钮,点击按钮回到顶部的功能,一般scrollview会有滑动监听的事件,通过setOnScrollChangeListener()滑动监听滑动的距离来判断是否显示按钮就好了,但是Pu ...

  3. Java学习之控制跳转语句

    控制跳转语句 控制跳转语句: (1)break:中断的意思 A:用在循环和switch语句中,离开此应用场景无意义. B:作用 a:跳出单层循环 b:跳出多层循环,需要标签语句的配合 (2)conti ...

  4. Spring之Enterprise JavaBeans (EJB) integration

    原文地址:需要FQ https://translate.google.com/translate?hl=zh-CN&sl=zh-CN&tl=zh-CN&u=http%3A%2F ...

  5. android自定义view实现progressbar的效果

    一键清理是很多Launcher都会带有的功能,其效果也比较美观.实现方式也许有很多中,其中常见的是使用图片drawable来完成的,具体可以参考这篇文章:模仿实现360桌面水晶球式的一键清理特效.本文 ...

  6. JVM学习之-栈

    JVM栈解决程序的运行问题,即程序如何执行,或者说如何处理数据;JVM堆解决的是数据存储的问题,即数据怎么放.放在哪儿,另外JVM堆中存的是对象.JVM栈中存的是基本数据类型和JVM堆中对象的引用. ...

  7. springMVC源码分析--国际化LocaleResolver(一)

    springMVC给我们提供了国际化支持,简单来说就是设置整个系统的运行语言,然后根据系统的运行语言来展示对应语言的页面,一般我们称之为多语言.springMVC国际化机制就是可以设置整个系统的运行语 ...

  8. ASP.net 路径问题 详解

    各位有没有碰到在日常工作中经常在路径设置的时候把 "~/ ../ .../ . / .http://www.cnblogs.com/"这些符号搞混搞乱了?偶尔还会因路径的问题郁闷了 ...

  9. 【一天一道LeetCode】#342. Power of Four

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...

  10. UNIX网络编程——套接字选项(SO_RCVBUF和SO_SNDBUF)

    有时候我们需要控制套接字的行为(如修改缓冲区的大小),这个时候我们就要学习套接字选项. int getsockopt(int sockfd,int level,int optname,void *op ...