下面将为您介绍SQL Server创建服务的实现方法,该方法供您参考,如果您对SQL Server创建服务方面感兴趣的话,不妨一看。
服务代理程序体系架构
服务代理程序是基于服务代理程序的体系架构的。此体系架构由以下数据库对象组成:
消息:是在服务之间交换的数据。
服务:是会话的可寻址的端点。服务代理程序消息从一个服务发送到另一个服务。参加会话的两种类型的服务是发起者和处理服务。发起者服务发起会话,向处理服务发送消息。
消息类型:定义在会话的参与者之间交换的消息的内容。消息类型对象定义消息类型的名称和消息可包含的内容的类型。
约定:是定义将交换消息的参与应用程序之间的协定。必须在参与会话的每个参与数据库上创建相同的约定。
队列:是存储消息的容器。每个服务与一个队列关联。当为服务发送消息时,服务代理程序将消息放置在队列中。队列是以表的形式来表示的,其中每条消息是一行。每行包含消息和其信息,如消息类型、发起者和目标服务。
服务程序:是向服务提供逻辑的程序。当为服务接收消息时,服务代理程序自动发起服务程序,向程序转发消息。
实现服务代理程序
在实现服务代理程序之前,首先需要创建服务代理程序对象,如消息、队列、约定和服务。接下来,可开始会话。在会话开始之后,对象可通过发送和接收消息彼此之间进行通讯。
创建消息
消息是在服务代理程序服务之间交换的实体。消息需要一个名称来参与会话。消息可包含对消息处理的数据类型的验证。作为会话的一部分,消息具有***的标识符以及***的队列号来实现消息排队。
可使用CREATE MESSAGE命令来创建新的消息。CREATE MESSAGE命令的语法如下所示:
- CREATE MESSAGE TYPE message_type_name
- [ VALIDATION = { NONE | EMPTY | WELL_FORMED_XML | VALID_XML WITH SCHEMA COLLECTION schema_collection_name } ] [ ; ]
其中,
message_type_name 是想要创建的消息类型的名称。
VALIDATION 指定消息在发送之前应如何进行验证。默认值是 NONE。验证子句可采用以下值:
NONE: 表示未执行验证。
EMPTY: 表示消息正文必须是 NULL。
WELL_FORMED_XML: 表示消息必须是定义完好的 XML 代码段。
VALID_XML WITH SCHEMA COLLECTION: 验证使用现有模式在消息中出现的 XML 代码段。
【编辑推荐】