Пример скрипта службы
В этом образце кода Transact-SQL определяется служба, которая архивирует нетипизированные XML-документы. В образец входят два скрипта: скрипт контракта и скрипт определения службы. Скрипт контракта определяет типы сообщений и контракт для службы. Определение типа сообщений и определение контракта должны совпадать и для службы вызывающей стороны, и для целевой службы. Поэтому определения включаются в отдельный скрипт определения службы, который может распространяться в базы данных, где размещается служба вызывающей стороны. Скрипт определения службы определяет саму службу. Этот скрипт должен выполняться только в базе данных, где реализована целевая служба.
![]() |
---|
Скрипт определения службы определяет целевую службу, но не содержит ее реализацию. |
Скрипт контракта
-- The contract script contains definitions that must be
-- present for both the intiating service and the target
-- service.
USE AdventureWorks2008R2;
GO
-- Create messages for each broker-to-broker
-- communication needed to complete the task.
-- Message for the initiator to send XML
-- to be archived.
CREATE MESSAGE TYPE
[//Adventure-Works.com/messages/ArchiveXML]
VALIDATION = WELL_FORMED_XML ;
GO
-- Message to return event archiving information.
CREATE MESSAGE TYPE
[//Adventure-Works.com/messages/AcknowledgeArchiveXML]
VALIDATION = WELL_FORMED_XML ;
GO
-- Create a service contract to structure
-- an event archiving conversation, using
-- the message types defined above.
CREATE CONTRACT
[//Adventure-Works.com/contracts/ArchiveXML/v1.0]
(
[//Adventure-Works.com/messages/ArchiveXML]
SENT BY INITIATOR,
[//Adventure-Works.com/messages/AcknowledgeArchiveXML]
SENT BY TARGET
) ;
GO
Скрипт определения службы
-- This script defines the target service. The
-- objects created by this script are only
-- required in a database that hosts the target
-- service.
USE AdventureWorks2008R2 ;
GO
-- Create the service queue that will receive
-- messages for conversations that implement
-- the ArchiveXML contract.
CREATE QUEUE ArchiveQueue ;
GO
-- Create the service object that exposes the
-- ArchiveEvents service contract and maps
-- it to the ArchiveQueue service queue.
CREATE SERVICE [//Adventure-Works.com/ArchiveService]
ON QUEUE ArchiveQueue
([//Adventure-Works.com/contracts/ArchiveXML/v1.0]) ;
GO