[200分]如何用一条SQL 语句删除表中重复的记录,但要保留一条,具体如下 :急等!!!!!!!!!(在线等待)

zsq666 2005-06-08 09:07:11
在emply表中有(id,name,sex)字段
 记录('001','张三','男')重复有10条
 记录('002','李死','')重复有8条
用一条SQL 语句删除表中重复的记录,但要保留一条!
...全文
196 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
mengzulin 2005-06-09
  • 打赏
  • 举报
回复
begin tran
select DISTINCT [id],[name],[sex] into #temp from emply
TRUNCATE TABLE emply
INSERT INTO emply([id],[name],[sex])
select [id],[name],[sex] from #temp
commit tran
net_cavalier 2005-06-08
  • 打赏
  • 举报
回复
Oracle 中可用:
delete from emply a where rowid > (select min(rowid) from emply where id=a.id and name=a.name and sex =a.sex)

Sql server中用一条语句难办,估计这种要求只有答题时才有,上面可应付了
paoluo 2005-06-08
  • 打赏
  • 举报
回复
在emply表中有(id,name,sex)字段
 记录('001','张三','男')重复有10条
 记录('002','李死','')重复有8条
用一条SQL 语句删除表中重复的记录,但要保留一条!
------------------------------------------------
常用的方法:借用临时表
Select Distinct * Into #T from emply
Delete from emply
Insert emply Select * from #T
Drop table #T
xluzhong 2005-06-08
  • 打赏
  • 举报
回复
create table a(id nvarchar(10),name nvarchar(10),sex nvarchar(10))
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
go
alter table a add sid int identity(1,1)
go
delete a from a t where sid not in (select top 1 sid from a where id=t.id order by sid)
go
alter table a drop column sid
go

select * from a

drop table a
xluzhong 2005-06-08
  • 打赏
  • 举报
回复
create table a(id nvarchar(10),name nvarchar(10),sex nvarchar(10))
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''
insert into a select '001','张三','男'
insert into a select '002','李死',''

select distinct * into #t from a
truncate table a

insert into a select * from #t

select * from a

drop table a,#t
xluzhong 2005-06-08
  • 打赏
  • 举报
回复
alter table emplay sid int identity(1,1)
go
delete a
from emplay a where id not in (select top 1 sid form emplay where id=a.id order by sid)
go
alter table emplay dorp column sid
zsq666 2005-06-08
  • 打赏
  • 举报
回复
up
zsq666 2005-06-08
  • 打赏
  • 举报
回复
up
代码下载地址: https://pan.quark.cn/s/35e46f7e83fb 关于 Build Status Lines of code 这是一个参考 PotPlayer 的界面使用 Java 以及图形界面框架 JavaFX 使用 MCV 图形界面与业务逻辑离的开发模式, 所开发的个人视频播放器项目, 开发这个项目旨在于学习图形界面框架 JavaFX 实现了具有和 PotPlayer相同 的简洁界面和流畅的操作逻辑。 Note: PotPlayer 是 KMPlayer 的原制作者姜龙喜先生(韩国)进入 Daum 公司后的 新一代网络播放器, PotPlayer的优势在于强大的内置解码器以及支持各类的 视频格式, 而且是免费下载提供使用的。 目前版本: 2020/10/28 v1.0.0 [x] 支持打开文件自动播放 [x] 支持查看播放记录 [x] 支持屏幕边沿窗口自动吸附 [x] 支持双击视频来播放和暂停 [x] 支持左键点击窗口任意位置来拖到窗口 [x] 支持左键双击播放窗口打开文件 [x] 支持根据视频尺寸自动调整窗口大小 [x] 支持根据播放文件类型调整窗口模式 [x] 支持根据视频尺寸自动调整窗口显示位置防止超出屏幕 [x] 支持记录上一次访问的文件路径 [x] 支持播放记录文件读写 已实现样式 未播放效果: 播放效果: 运行环境 本项目使用 NetBeans 配合 JDK 开发, NetBeans8.0 以及 JDK8.0 以上版本的均可以运行。 亦可使用其他集成开发环境, 例如 Eclipse, IntelliJ IDEA 配合使用 JDK8.0 以上版本均可构建此项目。 NetBeans download Eclipse downlo...

27,580

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧