首先为这个数据库开启Service Broker

ALTER DATABASE [T_EIP_UnityStore] SET ENABLE_BROKER

创建MessageType

CREATE MESSAGE TYPE SendACLDetails
                VALIDATION =
WELL_FORMED_XML;

创建Contract

CREATE
CONTRACT [ACLMainContract]
(
               SendACLDetails
SENT BY INITIATOR
);

创建发送到队列和从度列进行读取的存储过程

插入队列数据的存储过程

CREATE PROCEDURE [dbo].[KY_SendACLToQue]

@AclRights varchar(max)

AS

BEGIN

DECLARE @Message XML

Set  @Message=cast(@AclRights as XML);

DECLARE @Handle UNIQUEIDENTIFIER ;

BEGIN TRANSACTION

BEGIN DIALOG CONVERSATION @Handle FROM SERVICE svrACLUpd TO

SERVICE 'svrACLUpd' ON CONTRACT ACLMainContract WITH ENCRYPTION = OFF ;

SEND ON CONVERSATION @Handle MESSAGE TYPE SendACLDetails (@Message) ;

--PRINT 
CAST(@Message AS NVARCHAR(MAX))

COMMIT

END

GO

从队列中读取数据并处理的存储工程

CREATE PROCEDURE [dbo].[KY_ReceiveACLFromQue]

AS

BEGIN

DECLARE @Handle UNIQUEIDENTIFIER ;

DECLARE @MessageType SYSNAME ;

DECLARE @Message XML

DECLARE @FileId int

DECLARE @OperatorId int

DECLARE @AppId INT

DECLARE @InfoId VARCHAR(50)

DECLARE @isACLSplit VARCHAR(10)

DECLARE @PID TINYINT

DECLARE @RetryCount INT

exec   sp_addlinkedserver     'uuc_server','','SQLOLEDB','***\app0c'

exec   sp_addlinkedsrvlogin   'uuc_server','false',null,'sa','***'

exec   sp_serveroption 'uuc_server','rpc out','true' --这个允许调用链接服务器上的存储过程

BEGIN TRY

BEGIN TRANSACTION tr;

RECEIVE TOP ( 1 )

@Handle = conversation_handle,

@MessageType = message_type_name,

@Message = message_body FROM dbo.queSendACL;

IF ( @Handle IS NOT NULL

AND @Message IS NOT NULL

)

BEGIN

SET @OperatorId=CAST(CAST(@Message.query('/CusFileACLXML/OperatorId/text()') AS NVARCHAR(MAX)) AS INT)

SET @FileId=CAST(CAST(@Message.query('/CusFileACLXML/FileId/text()')
AS NVARCHAR(MAX)) AS INT)

SET @AppId=CAST(CAST(@Message.query('/CusFileACLXML/AppId/text()')
AS NVARCHAR(MAX)) AS INT)

SET @InfoId=CAST(CAST(@Message.query('/CusFileACLXML/InfoId/text()')
AS NVARCHAR(MAX)) AS varchar(50))

SET @isACLSplit=CAST(CAST(@Message.query('/CusFileACLXML/isACLSplit/text()') AS NVARCHAR(MAX)) AS varchar(10))

SET @PID=CAST(CAST(@Message.query('/CusFileACLXML/PID/text()')
AS NVARCHAR(MAX)) AS TINYINT)

DECLARE @i INT

DECLARE @Count INT

DECLARE @FileACLXML XML

SET @i=1

SET @Count=0

SET @FileACLXML=@Message.query('/CusFileACLXML/FileAcls/FileACL')

SET @count=@FileACLXML.value('count(/FileACL)','int')

WHILE @i<=@count

BEGIN

DECLARE @childXML XML

DECLARE @EncryptFileId VARCHAR(32)

DECLARE @OrgId INT

DECLARE @OrgName VARCHAR(200)

DECLARE @OrgTypeId INT

DECLARE @FileRight VARCHAR(16)

SELECT @childXML= @FileACLXML.query('/FileACL[position()=sql:variable("@i")]')

SET @EncryptFileId=@childXML.value('(/FileACL/EncryptFileId)[1]','varchar(32)')

SET @OrgId=@childXML.value('(/FileACL/OrgId)[1]','int')

SET @OrgName=@childXML.value('(/FileACL/OrgName)[1]','VARCHAR(200)')

SET @OrgTypeId=@childXML.value('(/FileACL/OrgTypeId)[1]','int')

SET @FileRight=@childXML.value('(/FileACL/FileRight)[1]','VARCHAR(16)')

--是否需要扩散到个人

IF @isACLSplit='true'

BEGIN

--个人

IF @OrgTypeId=1

BEGIN

EXEC [dbo].[KY_SaveFileAcl] @OperatorId,'',@AppId,@InfoId,@FileId,@EncryptFileId,@OrgId,@OrgName,@OrgTypeId,@FileRight,@PID

END

ELSE

BEGIN

CREATE table #tmpTable(OrganizeId INT,OrganizeName nvarchar(200),Flag int)

INSERT INTO #tmpTable(OrganizeId,OrganizeName)

EXEC KY_GetAllEmpListByorg @OrgId,@OrgTypeId

DECLARE
@tmpCount INT

DECLARE
@j INT

DECLARE
@OrganizeId INT

DECLARE
@OrganizeName VARCHAR(200)

SET @j=1;

SELECT @tmpCount = COUNT(OrganizeId) FROM #tmpTable

WHILE @j<=@tmpCount

BEGIN

SET @OrganizeId = (SELECT top(1) OrganizeId FROM #tmpTable where Flag IS NULL)

SET @OrganizeName=(SELECT OrganizeName FROM #tmpTable WHERE OrganizeId=@OrganizeId)

UPDATE #tmpTable SET Flag = 1 WHERE OrganizeId = @OrganizeId

EXEC [dbo].[KY_SaveFileAcl] @OperatorId,'',@AppId,@InfoId,@FileId,@EncryptFileId,@OrganizeId,@OrganizeName,1,@FileRight,@PID

SET @j=@j+1

END

DROP TABLE #tmpTable

END

END

ELSE

BEGIN

EXEC [dbo].[KY_SaveFileAcl] @OperatorId,'',@AppId,@InfoId,@FileId,@EncryptFileId,@OrgId,@OrgName,@OrgTypeId,@FileRight,@PID

END

SET @i=@i+1

END

EXEC [T_EIP_USPIndex].dbo.KY_DeleteACLQueue @OperatorId,@FileId

END

COMMIT transaction tr

END TRY

BEGIN CATCH

rollback transaction tr;

SET @RetryCount=CAST(CAST(@Message.query('/CusFileACLXML/RetryCount/text()') AS NVARCHAR(MAX)) AS INT)

DECLARE @messageStr varchar(max)

IF(@RetryCount < 3 )

BEGIN

PRINT '重试处理'

SET @RetryCount = @RetryCount + 1

EXEC [T_EIP_USPIndex].dbo.KY_UpdateACLQueuE 3,@RetryCount,@OperatorId,@FileId

SET @Message.modify('insert
<RetryCount>{sql:variable("@RetryCount")}</RetryCount>
into (/CusFileACLXML)[1]')

SET @messageStr = CAST(@Message AS VARCHAR(MAX))

exec dbo.KY_SendACLToQue @messageStr

END

ELSE

BEGIN

SET @messageStr = CAST(@Message AS VARCHAR(MAX))

--记录队列错误日志

PRINT '记录队列错误日志'

EXEC KY_InsertACLUpdateLog 1,@OperatorId,'',@InfoId,@AppId,@FileId,@EncryptFileId,NULL,

NULL,NULL,NULL,NULL,NULL,@messageStr,0,'ACL队列处理错误'

END

END CATCH

exec  sp_dropserver 'uuc_server','droplogins'

END

GO

创建队列

CREATE QUEUE queSendACL WITH
STATUS= ON

创建服务

CREATE SERVICE
svrACLUpd ON
QUEUE queSendACL ([ACLMainContract])

ServiceBroker创建流程的更多相关文章

  1. Magento代码之订单创建流程

    Magento代码之订单创建流程         直接看代码吧.下面的代码是如何通过程序创建一个完美订单.        <?php        require_once 'app/Mage. ...

  2. ADF 项目创建流程

    ADF 项目创建流程: 1.首先建好应用 2.创建model,UI 3.创建EO,VO,AO, VL 4.设置EO的属性 5.新建lov 6.设置VO的View Accessors,并设置Attrib ...

  3. MFC中SDI程序创建流程的回顾

    SDI程序创建流程的回顾 从CWinApp.InitialInstance()开始, 1.首先应用程序对象创建文档模板; CSingleDocTemplate* pDocTemplate; pDocT ...

  4. 【Java基础】Java类的加载和对象创建流程的详细分析

    相信我们在面试Java的时候总会有一些公司要做笔试题目的,而Java类的加载和对象创建流程的知识点也是常见的题目之一.接下来通过实例详细的分析一下. 实例问题 实例代码 Parent类 package ...

  5. Java类的加载和对象创建流程的详细分析

    相信我们在面试Java的时候总会有一些公司要做笔试题目的,而Java类的加载和对象创建流程的知识点也是常见的题目之一.接下来通过实例详细的分析一下: package com.test; public ...

  6. OpenStack Nova虚拟机创建流程解析

    https://yikun.github.io/2017/09/27/OpenStack-Nova%E8%99%9A%E6%8B%9F%E6%9C%BA%E5%88%9B%E5%BB%BA%E6%B5 ...

  7. 8 云计算系列之Horizon的安装与虚拟机创建流程

    preface 在上一章节中,我们可以在无web管理界面上创建并启动虚拟机,虽然可以这么做,但是敲命令太繁琐,所以此时我们可以安装openstack web管理界面,通过web界面的图形化操作open ...

  8. k8s 基础 pod创建流程

    Pod是Kubernetes中最基本的部署调度单元,可以包含container,逻辑上表示某种应用的一个实例.例如一个web站点应用由前端.后端及数据库构建而成,这三个组件将运行在各自的容器中,那么我 ...

  9. solr索引创建流程

    solr索引创建流程: 分词组件Tokenizer 分词组件(Tokenizer)会做以下几件事情(这个过程称为:Tokenize),处理得到的结果是词汇单元(Token). 1.将文档分成一个一个单 ...

随机推荐

  1. linux概念之用户,组及权限

    Linux 是一个多用户.多任务的操作系统:我们应该了解单用户多任务和多用户多任务的概念 单用户多任务一个beinan用户,为了完成工作,执行了几个任务:当然beinan这个用户,其它的人还能以远程登 ...

  2. bing统计【转自CSDN博客】

    文章来源:http://blog.csdn.net/aa512690069/article/details/17918799 其原文是微软一个小题目:http://hero.csdn.net/Ques ...

  3. wikioi 1206 保留两位小数 【考查浮点数输入输出】

    /*======================================================================== 1206 保留两位小数 题目描述 Descript ...

  4. 车载凯立德导航地图更新以及DSA数据更新方法

    每年升级每次都去重新摸索,1年时间忘完了,遂决定把他写下来,我这就去实验,实验好了来补 第一步: 找最新的凯立德软件和地图版本号 方法:淘宝搜索, 例如:凯立德 2016,搜索结果会出现比如2016 ...

  5. 阿里云nat mysql配置

    # Generated by iptables-save v1. :: *filter :INPUT DROP [:] :FORWARD ACCEPT [:] :OUTPUT ACCEPT [:] # ...

  6. spring 中事务的PROPAGATION_REQUIRED,Readonly的解释

                 一.事务传播行为种类 Spring在TransactionDefinition接口中规定了7种类型的事务传播行为, 它们规定了事务方法和事务方法发生嵌套调用时事务如何进行传播 ...

  7. php PDO连接数据库

    [PDO是啥] PDO是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接和处理,什么 php_mysql.dll.php_pgsql.d ...

  8. Force IE to Open Link in New Tab

    1.First, open Internet Explorer and click on Tools and then Internet Options. 2.Now click on the Set ...

  9. POJ 3709 K-Anonymous Sequence

    题目大意:将一个升序的,有N个元素的序列,分组.要求每组的元素不少于K个,计算出组内各元素与最小元素的之差的和,将每组的这个值加起来,其和要最小. N<500000,K<N 分析: dp[ ...

  10. Makefile所有内嵌函数

    一.文本处理函数以下是GNU make内嵌的文本(字符串)处理函数.1       $(subst FROM,TO,TEXT) 函数名称:字符串替换函数—subst. 函数功能:把字串“TEXT”中的 ...