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

来源:脚本之家  责任编辑:小易  

1、利用SQL Server 2012资源管理器创建数据库表t_call_info,包含有三个字段id、cno和cname。2、创建完毕后,刷新数据库book,这时会在表文件夹下生成数据库表t_call_info。3、向数据库表t_call_info插入10条数据。4、查询数据库表数据,这时会看到10条数据记录。5、在数据库鼠标右键创建新查询,如下图所示。6、在生成查询窗口,编辑动态查询SQL语句,声明整型tid、字符串型sql,然后赋值,最后调用参数执行SQL语句www.zgxue.com防采集请勿采集本网。

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

首先查询一下,ROW_NUMBER 效果是否满足预期 SELECT ROW_NUMBER()OVER(PARTITION BY name,value ORDER BY(SELECT 1))AS no, name, value FROM test_delete no name value 1 李四 80 1 王五 80 2 王五 80 1

复制代码 代码如下:

SQL数据库查询出一张表中重复的数据,按某个字段来查找的实例: 例如表名为Course: 需要查询出name的重复,解答如下: 补充: 如:查询每个姓名出现大于2次,SQL如下 SELECT COUNT(NAME)as '出现次数',

select * from people

你好:一种简单方式就是直接根据你不想要的数据进行分组后存储到另外一张表里面 create table as select*from b group id;可以写存储过程来实现判断重复数据后删除。另外一种方法就是插入的时候

where peopleId in (select   peopleId from   people group by   peopleId having count

1select 姓名列,count(1)as[重复次数]from 表名 group by 姓名列 having count(1)>=2 order by 重复次数 desc

(peopleId) > 1)

怕用别的方法删除出错的话,可以用 去重查询,放到另一张表中,删除后再放回去啊!select distinct*into A from B 去重存另一张表 delete B-删除B中数据 放回数据 insert into B select*from A

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

复制代码 代码如下:

delete from people

where peopleId in (select   peopleId from people group by   peopleId   having count

(peopleId) > 1)

怕用别的方法删除出错的话,可以用 去重查询,放到另一张表中,删除后再放回去啊!select distinct*into A from B 去重存另一张表 delete B-删除B中数据 放回数据 insert into B select*from A

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

)

select t.a,t.b,t.cfrom tgroup by t.a,t.b,t.chaving on count(t.*)>1内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • sql 查询和删除重复字段数据的方法
  • sql语句实现删除重复记录并只保留一条
  • 查询表中某字段有重复记录个数的方法
  • sql重复记录查询 查询多个字段、多表查询、删除重复记录的方法
  • sql server 的sql语句优化方式小结
  • 精妙的sql语句
  • sqlserver 获取字符串中小写字母的sql语句
  • 获取sqlserver存储过程定义的三种方法
  • oracle 10g各个帐号的访问权限、登录路径、监控状态命令查询等等
  • 学会sql数据库关系图(petshop)
  • sql server 2000管理单元初始化失败的解决方法
  • sql提取数据库表名及字段名等信息代码示例
  • 阿拉伯数字转大写中文_财务常用sql存储过程
  • sql server高级内容之case语法函数概述及使用
  • SQL重复记录查询的几种方法
  • sql查询去掉重复记录
  • SQL查询,如何去除重复的记录?
  • SQL重复查询的几种方法
  • 一个表中有重复记录如何用SQL语句查询出来。。。?
  • sql查询按两个字段查询重复记录
  • Oracle删除重复记录只保留一条数据的几种方法
  • 写一个sql 查询一个表中姓名相同的记录,并把数据按照重复的次数从高到低排列显示
  • sql数据库中出现重复行数据,如何删除这些重复记录?
  • Oracle数据库重复数据删除的几种方法
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mssqlsql 查询和删除重复字段数据的方法sql语句实现删除重复记录并只保留一条查询表中某字段有重复记录个数的方法sql重复记录查询 查询多个字段、多表查询、删除重复记录的方法sql server 的sql语句优化方式小结精妙的sql语句获取sqlserver存储过程定义的三种方法oracle 10g各个帐号的访问权限、登录路径、监控状态命令查询等等学会sql数据库关系图(petshop)sql server 2000管理单元初始化失败的解决方法sql提取数据库表名及字段名等信息代码示例阿拉伯数字转大写中文_财务常用sql存储过程sql server高级内容之case语法函数概述及使用sql server 2012 安装图解教程(附sql server数据库入门学习总结microsoft sql server 2012 数据sql重复记录查询的几种方法win7系统安装sqlserver2000的详细sqlserver中distinct的用法(不重sql server错误代码大全及解释(sql-order by 多字段排序(升序、sql将一个表中的数据插入到另一个用sql语句添加删除修改字段、一些监控 log文件大小的存储过程ip连接sql server失败(配置为字符串失败)sql语句中如何将datetime格式的日期转换为sqlserver利用存储过程去除重复行的sql语sql语句执行顺序详解如何恢复数据库备份到一个已存在的正在使分析sql语句性能3种方法分享sql server中的执行引擎入门 图解一个简单的sql 行列转换语句sql中varchar和nvarchar的区别与使用方法
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved