BEGIN CONVERSATION TIMER (Transact-SQL)

适用于:SQL ServerAzure SQL 托管实例

启动计时器。 当超时到期时,Service Broker 为对话在本地队列上放入 https://schemas.microsoft.com/SQL/ServiceBroker/DialogTimer 类型的消息。

Transact-SQL 语法约定

语法

BEGIN CONVERSATION TIMER ( conversation_handle )  
   TIMEOUT = timeout   
[ ; ]  

注意

若要查看 SQL Server 2014 (12.x) 及更早版本的 Transact-SQL 语法,请参阅早期版本文档

自变量

BEGIN CONVERSATION TIMER (conversation_handle)
指定要计时的会话。 conversation_handle 的类型必须为 uniqueidentifier

TIMEOUT
指定在将消息放入队列之前要等待的时间,以秒为单位。

备注

会话计时器为应用程序提供了一种方式,可以在指定时间后接收与某个会话有关的消息。 如果在计时器过期前对会话调用 BEGIN CONVERSATION TIMER,可将超时设置为新值。 与会话生存期不同,会话双方的会话计时器彼此独立。 DialogTimer 消息到达本地队列时,不会影响会话的远程端。 因此,应用程序可以将计时器消息用于任何目的。

例如,可以使用会话计时器避免应用程序过久地等待过期响应。 如果希望应用程序在 30 秒内完成对话,则可将对话的会话计时器设置为 60 秒(30 秒加 30 秒的宽限期)。 如果对话 60 秒后仍处于打开状态,则应用程序将收到一条关于该对话队列的超时消息。

此外,应用程序可以使用会话计时器请求在特定时间进行激活。 例如,可以创建一个服务,每隔几分钟报告活动连接数;或者创建一种服务,每天晚上报告未清的采购订单。 该服务将会话计时器设置为在所需时间过期;计时器过期时,Service Broker 将发送一条 DialogTimer 消息。 DialogTimer 消息导致 Service Broker 启动队列的激活存储过程。 该存储过程将向远程服务发送一条消息,并重新启动会话计时器。

BEGIN CONVERSATION TIMER 在用户定义函数中无效。

权限

在默认情况下,对会话服务具有 SEND 权限的用户、sysadmin 固定服务器角色的成员和 db_owner 固定数据库角色的成员具有设置会话计时器的权限

示例

以下示例为由 @dialog_handle 标识的对话设置两分钟的超时。

-- @dialog_handle is of type uniqueidentifier and  
-- contains a valid conversation handle.  
  
BEGIN CONVERSATION TIMER (@dialog_handle)  
TIMEOUT = 120 ;  

另请参阅

BEGIN DIALOG CONVERSATION (Transact-SQL)
END CONVERSATION (Transact-SQL)
RECEIVE (Transact-SQL)