基于LINQ TO SQL审批工作流引擎设计与应用.docVIP

基于LINQ TO SQL审批工作流引擎设计与应用.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于LINQ TO SQL审批工作流引擎设计与应用

基于LINQ TO SQL审批工作流引擎设计与应用   摘要:通过对工作流开放标准及参考接口、协同工作技术的研究,设计出一套基于微软LINQ技术的审批工作流引擎。引擎能够针对人员、项目、业务、状态等元素的控制实现对审批流程的任务调度、流程跟踪、协同审批、业务灵活扩展等关键环节。   关键词关键词:WorkFlow;工作流引擎;LINQ;任务调度   DOIDOI:10.11907/rjdk.143793   中图分类号:TP319   文献标识码:A文章编号文章编号2015)002010702   1工作流定义   工作流技术(WorkFlow)\[1\]是一种能将工作任务自动在多个用户或单位间流转的技术,是一种实现建模和过程管理的核心技术\[2\],它的出现能够有效约束和控制业务的审批过程,令审批和管理业务流程有序执行,很好地解决了审批业务中存在的审批流程滞后等问题。   工作流是由一系列相关流程构成的集合,流程与流程之间可能相互独立,也可能存在着依赖关系\[3\],其可表示为WF::(P,R)。   (1) P={P1,P2,……,Pn}:表示审批流程的集合。   (2) R={R1,R2,……,Rn}, Ri=(j≠k):表示一个审批流程与另外一个审批流程间存在的依赖关系。在毕业论文过程管理系统的审批过程中,“教师题目审核表审批”与“学生毕业论文选题审批”存在着依赖关系,时间上前者需早于后者完成,数据源上后者业务的数据来源也源于前者的业务。   (3) WP={W,A, Sstart,Send}:表示工作流的审批过程。其中W 表示审批过程中包含的有序步骤集合,A 表示引起步骤变迁的审批动作( 即工作流审批过程处于某一步骤时,执行某一动作,该动作执行后,审批过程进入下一个步骤)。Sstart表示该工作流审批过程的起始步骤, Send表示该工作流审批过程的终止步骤。   2工作流引擎架构设计   通过对工作流定义及现实中审批关键业务的特点,工作流引擎宜选用成熟的关系型数据库技术\[4\]。因此,本文所设计开发的工作流引擎选用SQL Server2008作为底层数据库,引擎中的数据模型通过关系数据表来建模,通过关系数据库中所提供的存储过程、触发器等机制,控制工作流中各审批过程的实现,审批业务中的事务并发控制通过关系数据库所提供的时间戳机制实现。   另外,微软公司在.NET平台中推出最新LINQ\[5\]通用数据访问技术,这种技术使用统一的查询语法对LINQ所支持的各种不同数据源做操作,极大地降低了数据访问技术的难度。因此,本文开发的审批工作流引擎采用LINQ TO SQL 这一轻量级的ORM解决方案来搭建。工作流引擎架构具体如图1所示。   图1基于LINQ TO SQL的工作流引擎架构   工作流引擎承担了流程任务流转的控制中心角色\[6\],其提供3 类接口。接口1 为审批业务系统中不同业务与工作流引擎的交互提供服务,系统能根据不同阶段的审批业务定义不同的工作流业务;接口2 为工作流过程管理系统对工作流引擎提供流程控制与调度工作,并能保证工作流程能正常推进及流程出错时的回溯;接口3 为工作流过程管理系统对工作流程引擎提供跟踪服务,跟踪整个工作流引擎的运行状态。   同时,为了增强工作流引擎的服务能力和灵活性,工作流引擎内部提供了数据访问组件、工作流自定义组件、审批日志组件和定时任务组件。引擎利用LINQ TO SQL生成的DataContext类及数据实体类来负责访问关系数据库,对工作流引擎运行相关的单位角色数据、流程控制、工作流模型数据进行读写;通过工作流自定义组件,为灵活配置审批业务的各步骤提供支持,通过审批日志组件,记录工作流运行时的各流程活动日志。利用SQL Server中的定期任务配合工作流引擎推动工作流流程的顺利执行。   3工作流引擎数据库设计   工作流引擎主要依靠工作流模型数据、流程控制数据、组织角色数据来推动审批数据流转\[7\]。工作流模型数据包括每一类审批程序的步骤以及触发步骤变迁的行为动作等信息;流程控制数据包括每一次审批相关的业务信息,如审批申报内容和各流程审批人审批记录等;组织角色数据涉及企业或部门的组织结构关系、用户、角色及权限等信息。因此,工作流引擎的模型数据、流程控制数据,以及审批业务系统的业务数据、组织角色数据都存储在关系数据库中。工作流引擎数据库逻辑结构如图2所示。   图2工作流引擎数据库逻辑结构   (1)WorkFlow表。包含工作流名称及所关联的对象名称,不局限于某种特定类型的审批业务,通过关联到的不同审批业务对象表,可实现工作流引擎的通用性。   (2)WFOwnerGroup表。表示在不同状态下拥有审批业

文档评论(0)

317960162 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档