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

浏览:65日期:2024-01-18
数据库结构的脚本: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]GOALTER TABLE [dbo].[TempA] ADD CONSTRAINT [PK_TempA] PRIMARY KEY; CLUSTERED ([id]); ON [PRIMARY] GOTempA表中有三个字段,id唯一且为主键,自动增长;;PositionName,EnglishPositionName中有重复的记录,比如:id;;;PositionName;;;;;EnglishPositionName20;;其他Others21;;质量工程师;;;;;;;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)
相关文章: