电脑技术学习

使用一条SQL语句删除表中重复记录

dn001
数据库结构的脚本:
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)