一条sql语句删除表中重复记录

发布时间:2020-03-14编辑:脚本学堂
分享一例Sql语句代码,一条sql语句删除表中的所有重复记录,有需要的朋友可以参考学习下。

本节内容:
用一条sql语句删除表中的重复记录

1,数据库结构的脚本:
 

复制代码 代码示例:

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[TempA]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[TempA]
GO

CREATE TABLE [dbo].[TempA] (
 [id] [int] IDENTITY (1, 1) NOT NULL ,
 [PositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL ,
 [EnglishPositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO

ALTER TABLE [dbo].[TempA] ADD
 CONSTRAINT [PK_TempA] PRIMARY KEY  CLUSTERED
 (
  [id]
 )  ON [PRIMARY]
GO

TempA表中有三个字段,id唯一且为主键,自动增长;
PositionName,EnglishPositionName中有重复的记录。

例如:
 

id      PositionName        EnglishPositionName
20     其他                           Others
21     质量工程师               QC Engineer
22     其他                           Others
.......
100  质量工程师               QC Engineer

要求删除重复的"其他","质量工程师"等记录。

sql语句:
 

复制代码 代码示例:
Delete from TempA where id not in (
        select max(t1.id) from TempA t1 group by
         t1.PositionName,t1.EnglishPositionName)

说明:
1,要删除哪几个用于判断重复的字段,则将它们放在group by语句之后。
2,max(t1.id) 可以修改为:min(t1.id)