表中只有一个字段“描述”,请问如何将相同的数据记录合并,并更新数据表(确保没有相同的记录)
解决方案 »
- 求时间之间的计算
- 菜鸟想学习sql技术,向前辈求教
- 如果在结果中去掉不想要的元素?
- 请问这段建立表的SQL代码如何解释!
- master库是否可以隐藏或者怎么处理一下让别人在企业管理器中看不到,请高手帮忙给解释一下!!!!
- 字段查询问题
- 数据库移植问题(ms sql2008->oracle 10g)求助!
- SQL Server启不来了。
- 在VFP中我照着一个原有表单程序(表单有一个页框,四页面的),我想修改原来的四页面,想直截生成一个新表单程序,现在我已设计好,但一运行却什么都没有。主要会是什么原因呢?
- 自己挖的坑,流着泪也要填完啊.列数超过255列的表怎么 做发布和订阅啊.
- sqlserver2008怎么上传到ftp
- 同一个表,SELECT同时再进行INSERT的问题!
delete A from (SELECT 描述,ROW_NUMBER()OVER(PARTITION BY 描述 ORDER BY 描述 ) NUMBER
FROM TB) A
where NUMBER>1
(
SELECT rowno=ROW_NUMBER() OVER(PARTITION BY 描述 ORDER BY GETDATE()), * FROM tb
)
DELETE cte
WHERE rowno <> 1
--> --> (Roy)生成測試數據
if not object_id('Tempdb..#T') is null
drop table #T
Go
Create table #T([Num] int,[Name] nvarchar(1))
Insert #T
select 1,N'A' union all
select 1,N'A' union all
select 1,N'A' union all
select 2,N'B' union all
select 2,N'B'
Go方法1:
if object_id('Tempdb..#') is not null
drop table #
Select distinct * into # from #T--排除重复记录结果集生成临时表#truncate table #T--清空表insert #T select * from # --把临时表#插入到表#T中--查看结果
select * from #T/*
Num Name
----------- ----
1 A
2 B(2 行受影响)
*/--重新执行测试数据后用方法2
方法2:alter table #T add ID int identity--新增标识列
go
delete a from #T a where exists(select 1 from #T where Num=a.Num and Name=a.Name and ID>a.ID)--只保留一条记录
go
alter table #T drop column ID--删除标识列--查看结果
select * from #T/*
Num Name
----------- ----
1 A
2 B(2 行受影响)*/--重新执行测试数据后用方法3
方法3:
declare Roy_Cursor cursor local for
select count(1)-1,Num,Name from #T group by Num,Name having count(1)>1
declare @con int,@Num int,@Name nvarchar(1)
open Roy_Cursor
fetch next from Roy_Cursor into @con,@Num,@Name
while @@Fetch_status=0
begin
set rowcount @con;
delete #T where Num=@Num and Name=@Name
set rowcount 0;
fetch next from Roy_Cursor into @con,@Num,@Name
end
close Roy_Cursor
deallocate Roy_Cursor--查看结果
select * from #T
/*
Num Name
----------- ----
1 A
2 B(2 行受影响)
*/