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

王朝mssql·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

数据库结构的脚本:

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)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航