`

有重复数据时只显示一条记录

阅读更多
if not object_id('tempdb..#T') is null --判断是否存在临时表#T
drop table #T --如果存在则删除
go

create table #T   --#T是一个临时表,创建存储在系统数据库的tempdb数据库中,用了以后重启数据库服务就会释放.
(
	[id] int,
	[name] varchar(1),
	[memo] varchar(2)
)
go

select * from #T
go

insert into #T
select 1,N'A',N'A1' union all
select 2,N'A',N'A2' union all
select 3,N'A',N'A3' union all
select 4,N'B',N'B1' union all
select 5,N'B',N'B2'
go

select * from #T a where not exists (select 1 from #T where [name]=a.[name] and id<a.id)
--这里的select 1 代表的是一个常量,因为exists返回的是一个boolean值,所以只要一个值就可以了,也就是说也可以是select 2 select 3

 

  该语句执行过程:

  首先要知道not exists是不存在的意思

  比如定位到 1,N'A',N'A1' 时,在表里找到name='A',并且不存在id比这条记录还小的记录就返回真.显然这个满足

   以下两条不满足,因为name='A'时,还有一个id=1

   2,N'A',N'A2'  

   3,N'A',N'A3'

 

  这些语句都是取Name相同ID最小的记录(推荐用1,2,3),方法3在SQL05时,效率高于1、2

 

    方法2:自联接的方式

select a.* from #T a join (select min(id) id,[name] from #T group by [name])b 
on a.id=b.id and a.[name]=b.[name]

 

    方法3:

select * from #T a where id=(select min(id) from #T where a.[name]=[name])

 

    方法4:

select a.* from #T a join #T b on a.[name]=b.[name] and a.id>=b.id   
group by a.[name],a.id,a.memo having count(1)=1   
  
--取自连接分组后总记录数为1的结果   
--having就是对GROUP BY 进行筛选.   
--having count(1)=1 筛选出总记录数为1的数据.   
--join就是inner join    
--count(1)=1 就相当于count(*)=1,count()里面用什么都一样的,不管是某个
--表中存在的字段,还是*,还是1,还是其他什么的都一样的.  

 

分享到:
评论

相关推荐

    MySQL 查询重复内容只显示一条

    3. **只显示一条重复内容**:若要保留重复数据中的某一条,可以选择其中的一个特定记录,比如按ID排序后的第一条或者最后一条。以下是一种方法,保留`id`最小的重复记录: ```sql SELECT t1.* FROM ( SELECT ...

    Oracle查询重复数据并删除,只保留一条记录.docx

    Oracle 查询重复数据并删除,只保留一条记录 Oracle 是一种关系型数据库管理系统,广泛应用于企业级数据库管理。然而,在实际应用中,数据重复问题经常会出现,例如在资源目录在线编目的资源项子表中存在多条重发...

    删除数据库中重复的数据(只保留一条)

    在数据库管理过程中,经常会遇到需要清理数据的情况,其中一种常见需求就是删除数据库中的重复记录,同时确保每条数据的关键字段只保留一条记录。这种操作在维护数据一致性、提高查询效率等方面具有重要意义。根据...

    oracel重复记录只保留一条

    oracel重复记录只保留一条,提供sql语句与存储过程2种处理方式

    MySQL根据某一个或者多个字段查找重复数据的sql语句

    sql 查出一张表中重复...2、查询出所有数据进行分组之后,和重复数据的重复次数的查询数据,先列下: select count(username) as '重复次数',username from xi group by username having count(*)&gt;1 order by userna

    C# 用SQL自动记录数据并且查询出某一列有哪些重复数据

    本主题聚焦于如何在C#中利用SQL来自动记录数据,并查询出某一列中的重复数据。以下将详细讲解这一过程,以及相关知识点。 首先,我们需要理解C#和SQL的基础。C#是一种面向对象的编程语言,广泛应用于开发Windows...

    oracle 查询重复数据

    在数据库术语中,重复数据通常指的是在数据集中存在一个或多个字段完全相同的记录。这种现象可能由数据录入错误、系统故障、数据导入问题或业务流程设计不当等原因造成。重复数据不仅占用额外的存储空间,还可能导致...

    检查GridControl列表视图某列是否有重复数据

    5. **报告结果**:如果有重复数据,可以记录下这些值,并向用户显示。这可能包括显示警告对话框,或者在日志中记录详细信息。 以下是一个简单的C#代码示例,演示了这个过程: ```csharp using System; using ...

    解决Oracle删除重复数据只留一条的方法详解

    查询及删除重复记录的SQL语句1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断select * from 表 where Id in (select Id from 表 group by Id having count(Id) &gt; 1)2、删除表中多余的重复记录,...

    sqlServer删除重复数据

    重复数据可能是完全重复的记录,也可能是部分关键字段重复的记录。删除重复数据可以使用多种方法,包括使用 SELECT DISTINCT 语句、使用自动生成的标识符、使用游标、使用子查询等。 完全重复的记录 完全重复的...

    SQL语句删除数据表中重复的记录

    在数据库管理中,有时我们需要确保数据表中的记录是唯一的,避免重复数据导致的不一致性和冗余。在SQL中,可以使用特定的查询语句来删除重复的记录,以保持数据的整洁和准确。以下是如何使用SQL语句来删除数据表中...

    删除Access数据库中重复的数据

    当表中的某列或几列有相同的值时,我们就说存在重复数据。 删除Access数据库中重复数据的过程可以分为以下几个步骤: 1. **选择要清理的表**:首先,你需要确定哪个表需要进行重复数据清理。这通常基于表中特定列...

    查询重复数据sql语句

    - 当只需要知道是否存在重复数据而不需要具体的重复记录时,可以使用`COUNT(DISTINCT column_name)`。 - 示例:`SELECT COUNT(DISTINCT id) FROM a;` ### 总结 本文详细介绍了如何使用SQL查询表中的重复数据,...

    sqlserver中重复数据值只取一条的sql语句

    当数据库表中的某些列有重复的值时,我们可能需要仅选取其中的一条记录,例如,选择每组重复数据的第一条或者最后一条。题目中提到的SQL语句就是解决这类问题的一个示例。 首先,我们创建一个名为`TestData`的数据...

    kettle统计重复记录个数及明细

    通过以上步骤,我们不仅可以了解数据中重复记录的数量,还可以深入理解每条重复记录的详细信息,这对于数据治理、数据质量检查和业务洞察都至关重要。在实际工作中,Kettle这样的ETL工具可以帮助我们高效地处理复杂...

    by语句删除重复并保持一条重复记录

    by语句删除重复并保持一条重复记录,解决数据集中有重复记录的问题

    删除Access数据库中重复的记录

    在Access中一般只能查找10行大概20条重复记录,这样程序就可以任意指定表及多字段检索重复记录,并把重复的记录移除到一个临时表中,并不是进行真正删除,你可以进行恢复。但是执行第二次查找时则自动删除上次查找的...

    Oracle查询重复数据与删除重复记录方法(txt)

    ### Oracle查询重复数据与删除重复记录方法 在Oracle数据库中,有时我们需要找出并处理重复的数据。这不仅可以提高数据质量,还能提升查询效率。本文将详细介绍几种常用的查询和删除Oracle数据库中重复记录的方法。...

    去除重复数据,去除重复数据算法

    在计算机科学中,“去除重复数据”通常指的是从一组数据中移除重复出现的数据项,只保留唯一的值。这种操作对于提高数据处理效率、减少存储空间需求等方面具有重要意义。去重可以应用于多种场景,比如数据库操作、...

    使用aggregate在MongoDB中查询重复数据记录的方法

    在本场景中,我们将探讨如何利用`aggregate`来查询和处理重复数据记录。 首先,理解`aggregate`的基本用法至关重要。在MongoDB中,`db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)`命令用于对特定集合执行一...

Global site tag (gtag.js) - Google Analytics