转自:http://hi.baidu.com/fegro/item/d4abe46fc16bed03a0cf0f6a
注:以下内容在Oracle 10g下测试
由于设计需要,需要查询不重复的记 录值,同类问题,想必大家都遇到过,于是乎马上GOOGLE一下,发现此类问题还挺多,解决方案也不少,仔细看看。
例如有如下表结构和值
table
fid name sex
1 a 男
2 b 男
3 c 女
4 d 女
5 a 男
6 b 男
方案一:distinct
select distinct name from table
得到结果:
name
a
b
c
d
实现效果,那如 果要同时打开其它记录呢?再试试
select distinct name,id from table
测试没什么效果,查下得知,这样 实际是要name和id字段都重复才被筛选。继续查找可得如下方法:
方案二:group by
select *, count(distinct name) from table group by name
Oracle下测试失败,据说MYSQL下通过,不管,继续思考....
翻翻书,试试
select min(fid),name,sex from table group by name
成功,现实如下结果:
fid name sex
1 a 男
2 b 男
3 c 女
4 d 女
继续思考,如果要打开所有记录,不指定字段用(*),貌似这方法就不行了!
select * from table where fid in(Select min(fid) FROM table group by name)
测试成功
fid name sex
1 a 男
2 b 男
3 c 女
4 d 女
方案三:
本来已经完了,突然想起前几天在网上查了查询数据中所有某字段重复的记录
select * from table where name in(select name from table group by name having count(name)=2)
得到如下结果:
fid name sex
1 a 男
2 b 男
5 a 男
6 b 男
以此类推:
select * from table where name in(select name from table group by name having count(name)=1)
按道理说没问题,大家试试~~
再多的字段 都全部现实。哎,原来如此简单!回顾网上方法distinct,Inner Join等等,麻烦,而且有很大局限性.
总结如下:
select distinct name from table打开重复记录的单个字段
select * from table where fid in(Select min(fid) FROM table group by name)打开重复记录的所有字段值
select * from table where name in(select name from table group by name having count(name)=1)打开重复任意次数的所有记录
分享到:
相关推荐
根据提供的标题、描述以及部分代码内容,我们可以整理出关于如何使用SQL语句查询及处理重复记录的相关知识点。本文将详细阐述这些知识点,并提供具体的SQL语句示例。 ### SQL语句查询所有重复记录 #### 1. 查询...
如果想查找表中多余的重复记录,且重复记录是根据多个字段来判断,并且不包含 rowid 最小的记录,可以使用以下 SQL 语句: ```sql SELECT * FROM vitae a WHERE (a.peopleId, a.seq) IN (SELECT peopleId, seq ...
在这种方法中,我们首先将重复的记录记入一个临时表temp1,然后将不重复的记录记入另一个临时表temp2,最后删除原表中的重复记录并将temp2中的记录插入回原表。 优点:这种方法可以快速删除重复记录,且对大型...
描述中提到的问题是开发人员在查询和统计时可能遇到的挑战,即由于重复记录导致的结果不准确。下面我们将详细介绍一种不需要使用游标,而是通过四步操作来删除重复记录的方法。 首先,我们需要一个具有重复记录的...
5. **查询多个字段的重复记录,但不包括 `ROWID` 最小的记录**: 如果需要查看所有重复记录,但不包括 `ROWID` 最小的记录,可以使用: ```sql select * from 表 a where (a.Id,a.seq) in (select Id,seq from 表...
对于重复记录的处理是维护数据库完整性和提高查询效率的重要手段之一。本文将详细介绍四种基本的SQL语句删除重复记录的方法。 #### 方法一:使用临时表删除重复记录 **步骤1:** 首先创建一个临时表`temp1`,用于...
SQL语句去掉重复记录,获取重复...本文介绍了如何使用SQL语句去掉重复记录、获取重复记录,并且提供了SQL Server和Access中查询所有表名和字段名的方法。这些技术可以帮助开发者和数据库管理员更好地管理和维护数据库。
- 当只需要知道是否存在重复数据而不需要具体的重复记录时,可以使用`COUNT(DISTINCT column_name)`。 - 示例:`SELECT COUNT(DISTINCT id) FROM a;` ### 总结 本文详细介绍了如何使用SQL查询表中的重复数据,...
SQL 重复记录处理是数据库管理中的常见问题,尤其是在数据清洗和数据整合时。以下是对标题和描述中涉及的知识点的详细说明: **一、查询重复记录** 1. **多字段重复查询**: 使用自连接可以查询多字段同时重复的...
根据提供的标题、描述以及部分内容,本文将详细介绍使用SQL删除数据库表中的重复记录的不同方法。在实际操作中,去除重复数据是数据库管理中的常见需求之一,尤其是当数据来源于多个不同的源或者由于历史原因导致...
在SQL中删除重复记录是一个常见的需求,特别是在处理大型数据集时。本文将介绍几种有效的方法,以帮助你在遇到重复记录问题时能有效地清理数据。我们将以Oracle数据库为例,但这些方法在其他SQL数据库系统中也具有...
总之,SQL提供了多种方式来处理数据表中的重复记录,包括查询和删除。选择哪种方法取决于具体的需求,例如是否考虑多个字段的重复,是否保留特定的重复记录等。在实际操作中,务必谨慎执行删除操作,确保不会丢失...
标题与描述概述的知识点是关于如何使用SQL语句来删除数据库表中的重复记录,这是一个在数据清理和维护数据完整性时非常实用的技术。以下是对给定文件中四种方法的详细解析和扩展,旨在帮助读者深入理解并掌握这些...
本教程将深入讲解如何在SQL数据库中检测并删除重复记录,以确保数据的唯一性和准确性。 首先,我们需要理解SQL中的"唯一性"。一个表的字段如果要求唯一,意味着每个值在这个字段中只能出现一次。例如,员工ID或电子...
SQL重复记录查询的几种方法 SQL重复记录查询是数据库管理中非常重要的一方面,今天我们将讨论各种方法来查询和删除重复记录。 一、查找表中多余的重复记录 查找表中多余的重复记录可以使用以下方法: ```sql ...
SQL Server 删除重复数据 SQL Server 删除重复数据是数据库管理中的一项重要任务。重复数据可能是完全重复的记录,也可能是部分关键字段重复...删除重复数据需要根据实际情况选择合适的方法,才能正确地删除重复记录。
在SQL中,删除重复记录是一项常见的数据库管理任务,特别是在数据清洗和整理时。本文将详细介绍四种有效的方法来处理这个问题。 **方法1:使用临时表** 这种方法通过创建临时表temp1来存储重复记录,并最终将不重复...
1. **查找重复记录**:使用`GROUP BY`和`HAVING`子句找出`peopleId`出现多次的记录: ```sql SELECT peopleId FROM people GROUP BY peopleId HAVING COUNT(peopleId) > 1 ``` 这将返回所有重复的`peopleId`。 ...
sql 查出一张表中重复的所有记录数据 1.表中有id和name 两个字段,查询出name重复的所有数据 select * from xi a where (a.username) in (select username from xi group by username having count(*) > 1) 2、...