Usando o SqlNotificationRequest para assinar notificações de consulta
Assinar uma notificação usando o SqlNotificationRequest requer que se preparem os objetos Agente de Serviços subjacentes antes que o aplicativo possa solicitar a notificação. Depois que a assinatura for solicitada, o aplicativo monitorará a fila para obter uma mensagem de notificação e reagirá adequadamente quando a receber.
O SQL Server fornece notificações de consulta por meio do Agente de Serviços. Uma mensagem de notificação de consulta tem o nome de tipo de mensagem https://schemas.microsoft.com/SQL/Notifications/QueryNotification. O Agente de Serviços valida mensagens desse tipo como VALID_XML WITH SCHEMA COLLECTION. Para assinaturas criadas com SqlNotificationRequest, o aplicativo é responsável por monitorar a fila e processar as mensagens de notificação. Portanto, usar SqlNotificationRequest requer a implementação de um aplicativo externo. Este tópico discute as etapas específicas necessárias à assinatura de uma notificação de consulta usando SqlNotificationRequest. Para obter mais informações sobre como criar um aplicativo para processar mensagens de notificação de consulta, consulte Benefícios de programar com o Service Broker.
SqlNotificationRequest deve especificar um serviço para receber as mensagens de notificação. Para criar o serviço é necessário gerar uma fila para o serviço usar e depois criar o serviço. É igualmente necessário criar uma rota para o serviço no banco de dados local.
O Mecanismo de Banco de Dados usa o contrato https://schemas.microsoft.com/SQL/Notifications/PostQueryNotification para enviar mensagens de notificação, de modo que o serviço que você criar deverá aceitar conversações segundo esse contrato. O exemplo a seguir gera um serviço denominado WebCacheNotifications que usa a fila WebCacheMessages e depois cria uma rota para o serviço de WebCacheNotifications no banco de dados local.
USE AdventureWorks ;
CREATE QUEUE WebSiteCacheMessages ;
CREATE SERVICE WebCacheNotifications
ON QUEUE WebSiteCacheMessages
([https://schemas.microsoft.com/SQL/Notifications/PostQueryNotification]) ;
CREATE ROUTE
WebCacheMessagesRoute
WITH SERVICE_NAME = 'WebCacheNotifications',
ADDRESS = 'LOCAL' ;
O contrato https://schemas.microsoft.com/SQL/Notifications/PostQueryNotification especifica que mensagens do tipo https://schemas.microsoft.com/SQL/Notifications/QueryNotification podem ser enviadas pelo iniciador da conversação.
O nome do serviço no objeto SqlNotificationRequest é o nome do serviço Agente de Serviços. A notificação é criada como uma mensagem do Agente de Serviços.
A solicitação de notificação precisa também conter uma cadeia de caracteres de mensagem para a solicitação. Quando o Mecanismo de Banco de Dados cria uma notificação para essa solicitação, a mensagem de notificação contém essa cadeia de caracteres de mensagem. A mensagem de notificação é um documento XML. Este documento contém um elemento de Mensagem que mantém a cadeia de caracteres de mensagem incluída na solicitação de notificação. O aplicativo usa a cadeia de caracteres de mensagem para identificar a consulta que corresponde à notificação.
As assinaturas de notificação são gerenciadas pelo uso da combinação da consulta com a mensagem. Se o aplicativo solicitar outra notificação com a mesma mensagem e a mesma consulta, o Mecanismo de Banco de Dados atualizará a assinatura da notificação em vez de criar uma nova assinatura. A mensagem pode ser qualquer cadeia de caracteres. Contudo, observe que o Mecanismo de Banco de Dados determina se duas mensagens devem ser iguais. Portanto, as opções definidas para as cadeias de caracteres do banco de dados que não são equivalentes no programa podem ser equivalentes no banco de dados. Por exemplo, o Mecanismo de Banco de Dados considera as cadeias de caracteres que diferem apenas no número de espaços à direita como sendo iguais.
O exemplo a seguir mostra um programa simples que cria uma assinatura de notificação que usa SqlNotificationRequest:
[Visual Basic]
Option Strict On
Imports System
Imports System.Data
Imports System.Data.Sql
Imports System.Data.SqlClient
Namespace Microsoft.Samples.SqlServer
Module NotificationSampleMain
Public Sub Main()
Try
' Connect to the AdventureWorks database in the default instance
' on this server, using integrated security. If you change this
' connection string, be sure to change the service string below.
Using connection As SqlConnection = _
new SqlConnection("database=AdventureWorks;server=.;" + _
"Integrated Security=SSPI")
connection.Open()
' Define the service to receive the notifications. Update this
' information if you change the connection string.
Dim service As String = _
"WebCacheNotifications"
Dim query As String = _
"SELECT prod.Name, prod.Class, " + _
" prod.ProductNumber " + _
"FROM Production.Product as prod " + _
"WHERE prod.Color = 'Black' "
Dim command As SqlCommand = connection.CreateCommand()
command.CommandText = query
command.Notification = _
new SqlNotificationRequest(Guid.NewGuid().ToString(), _
service, _
Int32.MaxValue)
Dim reader As SqlDataReader = command.ExecuteReader()
' Normally, an application would process the results here.
MsgBox("Registered the notification.")
' Notice that the connection dispose method also
' disposes the commands and readers created from the
' connection.
End Using ' Using connection
' For sample purposes, simply display all exceptions and exit.
Catch e As SqlException
MsgBox("SqlException: " + e.Message + vbCrLf _
+ e.StackTrace )
Catch e As Exception
MsgBox("Exception: " + e.Message + vbCrLf _
+ e.StackTrace )
End Try
End Sub ' Main
End Module 'NotificationSampleMain
End Namespace ' Microsoft.Samples.SqlServer
Depois que esse código for executado, SQL Server contém uma assinatura de notificação de consulta. A assinatura produz uma notificação quando ocorrem alterações nos dados especificados na seguinte consulta:
SELECT prod.Name, prod.Class, prod.ProductNumber
FROM Products.Product as prod
WHERE prod.Color = 'Black'
O Agente de Serviços entrega as mensagens de notificação ao serviço WebCacheNotifications. Como esse serviço usa a fila WebCacheMessages, as mensagens de notificação aparecem nessa fila. Para processar as mensagens de notificação, o aplicativo monitora a fila WebCacheMessages.
Consulte também