处理表重复记录

--处理表重复记录(查询和删除) /****************************************************************************************************************************************************** 1、Num、Name相同的重复值记录,没有大小关系只保留一条 2、Name相同,ID有大小关系时,保留大或小其中一个记录 整理人:中国风(Roy) 日期:2008.06.06 ******************************************************************************************************************************************************/ --1、用于查询重复处理记录(如果列没有大小关系时2000用生成自增列和临时表处理,SQL2005用row_number函数处理) --> --> (Roy)生成測試數據 if not object_id('Tempdb..#T') is null     drop table #T Go Create table #T([ID] int,[Name] nvarchar(1),[Memo] nvarchar(2)) Insert #T select 1,N'A',N'A1' union all select 2,N'A',N'A2' union all select 3,N'A',N'A3' union all select 4,N'B',N'B1' union all select 5,N'B',N'B2' Go --I、Name相同ID最小的记录(推荐用1,2,3),方法3在SQl05时,效率高于1、2 方法1: Select * from #T a where not exists(select 1 from #T where Name=a.Name and ID<a.ID) 方法2: select a.* from #T a join (select min(ID)ID,Name from #T group by Name) b on a.Name=b.Name and a.ID=b.ID 方法3: select * from #T a where ID=(select min(ID) from #T where Name=a.Name) 方法4: select a.* from #T a join #T b on a.Name=b.Name and a.ID>=b.ID group by a.ID,a.Name,a.Memo having count(1)=1 方法5: select * from #T a group by ID,Name,Memo having ID=(select min(ID)from #T where Name=a.Name) 方法6: select * from #T a where (select count(1) from #T where Name=a.Name and ID<a.ID)=0 方法7: select * from #T a where ID=(select top 1 ID from #T where Name=a.name order by ID) 方法8: select * from #T a where ID!>all(select ID from #T where Name=a.Name) 方法9(注:ID为唯一时可用): select * from #T a where ID in(select min(ID) from #T group by Name) --SQL2005: 方法10: select ID,Name,Memo from (select *,min(ID)over(partition by Name) as MinID from #T a)T where ID=MinID 方法11: select ID,Name,Memo from (select *,row_number()over(partition by Name order by ID) as MinID from #T a)T where MinID=1 生成结果: /* ID          Name Memo ----------- ---- ---- 1           A    A1 4           B    B1 (2 行受影响) */ --II、Name相同ID最大的记录,与min相反: 方法1: Select * from #T a where not exists(select 1 from #T where Name=a.Name and ID>a.ID) 方法2: select a.* from #T a join (select max(ID)ID,Name from #T group by Name) b on a.Name=b.Name and a.ID=b.ID order by ID 方法3: select * from #T a where ID=(select max(ID) from #T where Name=a.Name) order by ID 方法4: select a.* from #T a join #T b on a.Name=b.Name and a.ID<=b.ID group by a.ID,a.Name,a.Memo having count(1)=1 方法5: select * from #T a group by ID,Name,Memo having ID=(select max(ID)from #T where Name=a.Name) 方法6: select * from #T a where (select count(1) from #T where Name=a.Name and ID>a.ID)=0 方法7: select * from #T a where ID=(select top 1 ID from #T where Name=a.name order by ID desc) 方法8: select * from #T a where ID!<all(select ID from #T where Name=a.Name) 方法9(注:ID为唯一时可用): select * from #T a where ID in(select max(ID) from #T group by Name) --SQL2005: 方法10: select ID,Name,Memo from (select *,max(ID)over(partition by Name) as MinID from #T a)T where ID=MinID 方法11: select ID,Name,Memo from (select *,row_number()over(partition by Name order by ID desc) as MinID from #T a)T where MinID=1 生成结果2: /* ID          Name Memo ----------- ---- ---- 3           A    A3 5           B    B2 (2 行受影响) */ --2、删除重复记录有大小关系时,保留大或小其中一个记录 --> --> (Roy)生成測試數據 if not object_id('Tempdb..#T') is null     drop table #T Go Create table #T([ID] int,[Name] nvarchar(1),[Memo] nvarchar(2)) Insert #T select 1,N'A',N'A1' union all select 2,N'A',N'A2' union all select 3,N'A',N'A3' union all select 4,N'B',N'B1' union all select 5,N'B',N'B2' Go --I、Name相同ID最小的记录(推荐用1,2,3),保留最小一条 方法1: delete a from #T a where  exists(select 1 from #T where Name=a.Name and ID<a.ID) 方法2: deletefrom #T a left join (select min(ID)ID,Name from #T group by Name) b on a.Name=b.Name and a.ID=b.ID where b.Id is null 方法3: delete a from #T a where ID not in (select min(ID) from #T where Name=a.Name) 方法4(注:ID为唯一时可用): delete a from #T a where ID not in(select min(ID)from #T group by Name) 方法5: delete a from #T a where (select count(1) from #T where Name=a.Name and ID<a.ID)>0 方法6: delete a from #T a where ID<>(select top 1 ID from #T where Name=a.name order by ID) 方法7: delete a from #T a where ID>any(select ID from #T where Name=a.Name) select * from #T 生成结果: /* ID          Name Memo ----------- ---- ---- 1           A    A1 4           B    B1 (2 行受影响) */ --II、Name相同ID保留最大的一条记录: 方法1: delete a from #T a where  exists(select 1 from #T where Name=a.Name and ID>a.ID) 方法2: deletefrom #T a left join (select max(ID)ID,Name from #T group by Name) b on a.Name=b.Name and a.ID=b.ID where b.Id is null 方法3: delete a from #T a where ID not in (select max(ID) from #T where Name=a.Name) 方法4(注:ID为唯一时可用): delete a from #T a where ID not in(select max(ID)from #T group by Name) 方法5: delete a from #T a where (select count(1) from #T where Name=a.Name and ID>a.ID)>0 方法6: delete a from #T a where ID<>(select top 1 ID from #T where Name=a.name order by ID desc) 方法7: delete a from #T a where ID<any(select ID from #T where Name=a.Name) select * from #T /* ID          Name Memo ----------- ---- ---- 3           A    A3 5           B    B2 (2 行受影响) */ --3、删除重复记录没有大小关系时,处理重复值 --> --> (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 行受影响) */ 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
处理RabbitMQ重复提交的方法有多种。一种常见的解决方案是通过记录消息的唯一标识(如消息ID或消息内容的哈希值),并在消费者端进行去重操作。具体可以采用以下步骤: 1. 在消息的生产者端,为每个消息生成一个唯一的标识,并将该标识与消息一起发送到RabbitMQ队列中。可以使用消息ID、时间戳或者消息内容的哈希值作为唯一标识。 2. 在消费者端,接收到消息后,先判断该消息的唯一标识是否已经被处理过。可以通过查询数据库、缓存或者其他持久化存储来判断。 3. 如果该消息的唯一标识已经存在于记录中,说明该消息已经被处理过,可以选择直接忽略该消息或进行其他相应的操作,如记录日志。 4. 如果该消息的唯一标识不存在于记录中,说明该消息是新的,可以进行相应的业务处理,并将该消息的唯一标识记录下来,以便后续去重判断。 另外,还可以通过设置消息的过期时间,避免消息在队列中长时间滞留而导致重复消费的问题。可以设置一个合理的过期时间,让过期的消息自动被丢弃。 需要注意的是,以上方法只能解决消费端重复消费的问题,如果生产者发送了重复的消息,需要在生产者端进行相应的去重处理,例如在发送消息前进行判断,避免重复发送。同时,还需要考虑并发情况下的线程安全性。 总结一下,处理RabbitMQ重复提交的方法包括记录消息的唯一标识并在消费端进行去重操作,设置消息的过期时间,以及在生产者端进行去重处理。这些方法可以有效地避免重复消费和重复提交的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值