1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
 select * from people
 where peopleId in (select  peopleId  from  people  group  by  peopleId  having  count(peopleId) > 1)

 例二:
 select * from testtable
 where numeber in (select number from people group by number having count(number) > 1 )
 可以查出testtable表中number相同的记录
 
 2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
 delete from people 
 where peopleId  in (select  peopleId  from people  group  by  peopleId   having  count(peopleId) > 1)
 and rowid not in (select min(rowid) from  people  group by peopleId  having count(peopleId )>1)
 
 3、查找表中多余的重复记录(多个字段) 
 select * from vitae a
 where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq  having count(*) > 1)
 
 4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
 delete from vitae a
 where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
 and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
 
 
 5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
 select * from vitae a
 where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
 and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
 
 (二)
 比方说
 在A表中存在一个字段“name”,
 而且不同记录之间的“name”值有可能会相同,
 现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
 Select Name,Count(*) From A Group By Name Having Count(*) > 1
 
 如果还查性别也相同大则如下:
 Select Name,sex,Count(*) From A Group By Name,sex Having Count(*) > 1
 
 
 (三)
 方法一
 
 declare @max integer,@id integer
 
 declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) >; 1
 
 open cur_rows
 
 fetch cur_rows into @id,@max
 
 while @@fetch_status=0
 
 begin
 
 select @max = @max -1
 
 set rowcount @max
 
 delete from 表名 where 主字段 = @id
 
 fetch cur_rows into @id,@max
 
 end
 
 close cur_rows
 
 set rowcount 0
 
 方法二
 
   有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
 
 1、对于第一种重复,比较容易解决,使用
 
 select distinct * from tableName
 
 就可以得到无重复记录的结果集。
 
 如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除
 
 select distinct * into #Tmp from tableName
 
 drop table tableName
 
 select * into tableName from #Tmp
 
 drop table #Tmp
 
 发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。
 
 2、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下
 
 假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集
 
 select identity(int,1,1) as autoID, * into #Tmp from tableName
 
 select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID
 
 select * from #Tmp where autoID in(select autoID from #tmp2)
 
 最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)
 
 (四)
 查询重复
 
 select * from tablename where id in (
 
 select id from tablename 
 
 group by id 
 
 having count(id) > 1
 
 )

sql重复记录查询的更多相关文章

  1. SQL重复记录查询(转载)

     1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select * from people )  例二:  select * from testtable  where ...

  2. SQL重复记录查询的几种方法(转)

    1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 代码如下: select * from people ) 2.删除表中多余的重复记录,重复记录是根据单个字段(people ...

  3. 收藏:SQL重复记录查询 .

    来自:http://blog.csdn.net/chinmo/article/details/2184020 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select ...

  4. SQL重复记录查询-count与group by having结合查询重复记录

    查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select * from peoplewhere peopleId in (select  peopleId  from  p ...

  5. SQL重复记录查询的几种方法

    http://www.jb51.net/article/34820.htm \ 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 复制代码 代码如下: select * f ...

  6. **SQL某一表中重复某一字段重复记录查询与处理

    sql某一表中重复某一字段重复记录查询与处理   1.查询出重复记录  select 重复记录字段 form  数据表 group by houseno having count(重复记录字段)> ...

  7. SQL重复记录处理(查找,过滤,删除)

    SQL重复记录处理(查找,过滤,删除)     ID int    Title nvarchar(50)    AddDate datetime    数据  www.2cto.com     ID ...

  8. sql 重复数据查询

    具体代码: ); ORDER BY tcount DESC;

  9. mysql 多个字段重复记录查询

    select * from productstockquantity t where () ORDER BY t.CombinationI

随机推荐

  1. 20145233韩昊辰 《Java程序设计》实验报告一:Java开发环境的熟悉(Windows+IDEA)

    20145233 <Java程序设计>实验报告一:Java开发环境的熟悉 实验要求 使用JDK编译.运行简单的Java程序: 使用IDEA 编辑.编译.运行.调试Java程序. 实验内容 ...

  2. Quartz.NET syudy

    Quartz.NET   Quartz.NET是一个开源的作业调度框架,是OpenSymphony 的 Quartz API的.NET移植,它用C#写成,可用于winform和asp.net应用中.它 ...

  3. PHP PC端接入支付宝和微信感悟

    想着中秋节的时候把异步线程学习完,同事说有个PHP的支付要帮忙做一下,虽然中秋节计划是把C#的异步学完,不过还是喜欢挑战,好久没有像大学一样这么认真的熬夜解决问题了.由于在大学学过asp,它和php有 ...

  4. maven integration with eclipse 3.0.4 does not work with NTLM proxy

    Recently downloaded m2e(maven integration with eclipse). The version is 3.0.4. My environment is beh ...

  5. 学习之路三十五:Android和WCF通信 - 大数据压缩后传输

    最近一直在优化项目的性能,就在前几天找到了一些资料,终于有方案了,那就是压缩数据. 一丶前端和后端的压缩和解压缩流程 二丶优点和缺点 优点:①字符串的压缩率能够达到70%-80%左右 ②字符串数量更少 ...

  6. DOM系列---进阶篇

    内容提纲: 1.DOM类型 2.DOM扩展 3.DOM操作内容 一.DOM类型 DOM基础篇中,我们了解了DOM的节点并且了解怎样查询和操作节点,而本身这些不同的节点,又有着不同的类型.   DOM类 ...

  7. struts2升级报ActionContextCleanUp<<is deprecated。Please use the new filters

    把web.xml中配置struts.xml的文件改成 <?xml version="1.0" encoding="UTF-8"?> <web- ...

  8. 利用css3实现超出文本指定行数与省略号效果

    <style> .text1 {/*单行*/ width:200px; overflow:hidden; text-overflow:ellipsis; -o-text-overflow: ...

  9. WEB中的cookie

    首先来一篇好文章,刚好看到的: 沉默中的狂怒 —— Cookie 大喷发---------------- http://www.cnblogs.com/index-html/p/mitm-cookie ...

  10. Struts-1和2的比较

    Struts1和Struts2都是MVC设计模式的经典应用框架,下文从代码,性能,测试,功能等方面对Struts1和Struts2进行简单比较,来看看Struts的高级版本在哪些方面进行了优化. (1 ...