SQL查询数据库中完全相同的两条数据

SQL查询数据库中完全相同的两条数据,第1张

查询的 *** 作方法和步骤如下:

1、首先,创建一个测试表,如下图所示,然后进入下一步。

2、其次,完成上述步骤后,插入测试数据,如下图所示,然后进入下一步。

3、接着,完成上述步骤后,比较两个表的数据,可以发现表2的数据多于表1的数据,如下图所示,然后进入下一步。

4、然后,完成上述步骤后,表1比表2多了一些数据,如下图所示,然后进入下一步。

5、最后,完成上述步骤后,插入在表1中多的数据,执行sql,可以发现插入了多个记录,如下图所示。这样,问题就解决了。

select f1,f2,...,fn

from table

group by f1,f2,...,fn

having count(1)>1 查出存在相同的f1,f2,..,fn

想查找出记录则

select t1.* from table t1

join (select f1,f2,...,fn from table group by f1,f2,...,fn having count(1)>1) t2

on t1.f1=t2.f1 and t1.f2=t2.f2 and ... and t1.fn=t2.fn

结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。

1986年10月,美国国家标准协会对SQL进行规范后,以此作为关系式数据库管理系统的标准语言(ANSI X3. 135-1986),1987年得到国际标准组织的支持下成为国际标准。不过各种通行的数据库系统在其实践过程中都对SQL规范作了某些编改和扩充。所以,实际上不同数据库系统之间的SQL不能完全相互通用。

如果只是要查询不是重复的记录的话

select distinct * from 表

如果是将多余的重复记录删除

首先将不是重复的数据提取出来,保存到一个临时表中

select distinct * into #temp from 表

然后删除原来的表

delete from 表

最后往里面插入临时表的数据

insert into 表

select * from #temp


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9913163.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存