使用一条SQL语句删除表中重复记录,使用一条SQL语句删除表中重复记录
【 tulaoshi.com - Oracle教程 】
数据库结构的脚本:
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
采用的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) 
来源:http://www.tulaoshi.com/n/20160129/1493828.html
看过《使用一条SQL语句删除表中重复记录》的人还看了以下文章 更多>>