使用一条SQL语句删除表中重复记录
2012-03-28 11:19
357 查看
数据库结构的脚本: 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)
相关文章推荐
- 使用一条SQL语句删除表中重复记录
- 使用一条SQL语句删除表中重复记录
- 使用一条SQL语句删除表中重复记录
- 转:使用一条SQL语句删除表中重复记录
- 使用一条SQL语句删除表中重复记录
- 使用一条SQL语句删除表中重复记录
- 使用一条SQL语句删除表中重复记录
- 使用SQL语句查询表中重复记录并删除
- 如何使用SQL删除某个字段重复的记录,保留其中一条
- 如何使用Oracle查询并删除重复记录的SQL语句
- Oracle 删除重复数据只留一条 查询及删除重复记录的SQL语句 1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 select * from 表 wher
- SQL语句实现删除重复记录并只保留一条
- Oracle 删除重复数据只留一条 查询及删除重复记录的SQL语句 1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 select * from 表 wher
- MYSQL用一条SQL语句删除重复记录
- 删除oracle 表中重复数据sql语句、保留rowid最小的一条记录
- Sql server 删除重复记录的SQL语句保留一条
- MYSQL用一条SQL语句删除重复记录
- 用一条SQL语句删除重复记录
- 使用SQL语句对重复记录查询、统计重复次数、删除重复数据
- 关于mysql中删除重复记录,并保留重复数据中的一条数据的SQL语句理解