SQL Server查找与删除表重复记录sql语句
程序员文章站
2022-06-15 18:27:31
...
在SQL Server要查找与删除表中重复记录的方法有很多种,下面我来举出几种大家常用的并且性能效好的sql语句,有需要的朋友可参考。
在该示例中,我们将使用下表,它具有重复的 PK 值。在该表中,主键是两列(col1、col2)。我们无法创建唯一索引或主键约束,因为这两行具有重复的 PK。该过程演示如何识别和删除重复的主键。
代码如下 | 复制代码 |
create table t1(col1 int, col2 int, col3 char(50)) insert into t1 values (1, 1, 'data value one') insert into t1 values (1, 1, 'data value one') insert into t1 values (1, 2, 'data value two') |
第一步是识别哪些行具有重复的主键值:
代码如下 | 复制代码 |
SELECT col1, col2, count(*) |
5.从原始表中删除重复的行。例如:
代码如下 | 复制代码 |
DELETE t1 |
上面的方法是来自microsoft网站,下面我来收藏了网站的一些解决办法,大家可参考。
查找表中多余的重复记录(多个字段)
代码如下 | 复制代码 |
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、SQL Server查找表中多余的重复记录(多个字段),不包含rowid最小的记录
推荐阅读
-
在SQL Server中查询资料库的TABLE数量与名称的sql语句
-
SQL Server中的SQL语句优化与效率问题
-
关于mysql中删除重复记录,并保留重复数据中的一条数据的SQL语句的深入理解
-
SQL Server2008中删除重复记录的方法分享
-
Oracle 查找与删除表中重复记录的步骤方法
-
Sql Server里删除数据表中重复记录的例子
-
关于如何修改一张表中所有行与选定字段的同sql多行语句的添加方法
-
SQL Server查找表名或列名中包含空格的表和列实例代码
-
SQL Server根据分区表名查找所在的文件及文件组实现脚本
-
(Sql server)用现有表中的数据创建Sql的Insert插入语句