【发布时间】:2017-11-14 04:24:27
【问题描述】:
我创建了一个目标队列以使用服务代理在 sql server 中接收消息。我的目标队列是这样的:
USE [DatabaseB]
GO
ALTER QUEUE [dbo].[TargetQueue] WITH STATUS = OFF , RETENTION = OFF , ACTIVATION ( STATUS = ON , PROCEDURE_NAME = [dbo].[myp] , MAX_QUEUE_READERS = 10 , EXECUTE AS N'dbo' ), POISON_MESSAGE_HANDLING (STATUS = ON)
这是我在 target_queue 中收到消息时调用的存储过程
改变程序 [dbo].[myp]
AS
WHILE (1=1)
BEGIN
Declare @ConversationHandle as uniqueidentifier
Declare @MessageBody as nvarchar(max)
Declare @MessageType as sysname
Begin Transaction
Print 'Started Receiving ';
RECEIVE top (1)
@MessageType = message_type_name,
@ConversationHandle = conversation_handle,
@MessageBody = message_body
FROM TargetQueue;
if @MessageType = 'SenderMessageType'
Begin
SEND
ON CONVERSATION @ConversationHandle
Message Type ReceiverMessageType
('Message is received')
END Conversation @ConversationHandle
insert into table_1 (dataa) values ('salam')
END
Commit
end
但是当队列接收到消息时,我的存储过程将无限数据添加到 table_1 但我有一个条件,如您在上面看到的那样,我的意思是对于收到的每条消息,sp 应该在表中添加一行而不是无限行。为什么?
【问题讨论】:
标签: sql-server asynchronous stored-procedures service-broker