表单式工作流功能模块设计方案-程序员宅基地

技术标签: 表单式工作流  接口设计  系统设计  功能模块设计  项目经验  数据库设计  

最近一个项目中需要独自设计一个表单式工作流功能模块,在此将整个功能模块的设计思路分享出来。



1. 需求及分析

此处所有的需求是建立在医院临床信息管理系统之上的。这里只分析关于表单式工作流功能模块的需求。

关于表单式工作流功能模块的需求全部整理如下:

  • 1.一个患者在不同时期要填写的表单不同。
  • 2.每个患者的手术类型不同,也就意味着,每个患者的各个时期可能都不相同。
  • 3.每个时期需要单独填写多张表单,相同时期要填写表单的相同。
  • 4.在每个时期要填写的其中一张表单中,可能一条患者信息对应一条记录,也可能一条患者信息对应多条记录。比如在手术期的一张检查表单中,一条患者信息只对应一条记录,但是术后期的一张检查表单中,可能会有手术后30天的情况,也会有手术后60天的情况,也就是一条患者信息对应多条记录。
  • 5.对于某一个患者,要能单独的处理它的工作流(也就是不同时期的表单)。
  • 6.对于某一个时期,要能单独处理在这个时期的所有患者信息。
  • 7.对每张表单要有增删改查操作,在每个时期,都要能通过各种方式查询患者的信息。

针对这些需求,对整个工作流功能模块初步的想法大概是这个样子:

在这里插入图片描述

  • 1.每位患者可以绑定一个工作流程,称为表单式的工作流。
  • 2.每个流程由若干个节点组成。
  • 3.医生在一个时期处理完所有的表单后,点击完成该流程节点即可进入下一流程节点。
  • 4.医生还可以修改一个患者已经完成的流程节点的数据,但是无法查看还未达到的流程节点的数据。

2. 功能实现分析

上述要实现的表单式的工作流跟oa系统中的工作流不大一样,oa系统中的工作流一般是这样几个步骤:

  • 1.设计流程。上级设计一种办事的流程,其中包含若干个节点,一个节点代表着一个审批人,所有节点审批都通过后才算完成,一个节点不通过,就会被打回。
  • 2.发起流程。由普通员工发起一个流程申请,发起后,员工无法修改这张表单,随后这张表单会跟随流程一级一级审批。
  • 3.流程审批。有若干上级审批流程,点击审批通过,该表单就会进入下以流程节点,点审批失败,流程会终止或者打回。
  • 4.流程通过。所有流程通过之后,会得到流程通过的凭证,就可以拿着这个凭证去处理相关的事情。

整个oa系统的工作流功能的核心就是多级审批机制,但我们需求中的表单式的工作流,并不设计审批机制,整个工作流的功能可以简单理解为:一条患者信息选择流程后会在各个时期不停流动,在一个时期需要填写非常多的表单,这些表单填写完成后,医生点击进入下一流程,患者信息即可进入下一流程,但是这条患者信息已经留在了每个时期的表单中,医生仍然可以查看和修改这条信息。

oa式的工作流的实现非常复杂,市面上也有商业化和开源的工作流框架和引擎,但是针对我们这个需求来看,如果硬加使用,只会使整个业务更加复杂,因此,最好的办法就是自己设计一种简单工作流机制,实现上述全部的需求。

3. 工作流结构设计

根据上面的需求分析和功能实现的分析,设计的整个工作流结构如下:

在这里插入图片描述

  • 每个工作流包含若干个节点。
  • 每个节点包含基本信息和若干个表单。
  • 每个患者绑定一个工作流,患者在每个工作流节点需要处理多张表单。

4. 数据库设计

4.1 总设计思路

根据上面的分析,总的设计思路如下:

  • 每个不同的时期有一张主表,主要记载患者的id,每当有患者信息到达该节点时,记录患者的id,一共有两种方式记载。两种方式各有好处。综合考虑还是第1种方式最好。
    • 1.只记载患者信息的id。
    • 2.记载同步记载所有患者信息。
    • 不管使用哪种方法,都需要将患者的id作为主表的主键,这样方便查询子表中的信息。
    • 如果使用第1种方法,那么每张主表中其实主要就是吧包含主键。但在每个时期,都需要联合患者表一起查询数据。
    • 如果使用第2种方法,那么每张主表需要同步患者的所有信息,且不管在哪修改了患者信息,都需要在所有主表同步患者的消息。
  • 每个时期的若干小表都是主表的子表,包含该小表需要填写的所有数据字段,外键是主表的id。
  • 流程节点表中绑定一张主表。
    • 这样设计的好处就是,在每一个流程节点处,还能看到许多该流程节点的其它信息。
  • 工作流表绑定若干个流程节点。
  • 个患者绑定一个工作流,并且存储当前节点,下一节点。

4.1 各时期主表设计

各时期的主表主要干的事情就是存储患者信息的id,代表着患者正处于当前流程节点或者已经完成该流程节点。

患者id模式

  • 这种模式很简单,基本上不需要什么字段。
字段 说明
id 患者id
权限管理需要的其它字段

同步所有患者信息模式

  • 这种方式需要同步主表的所有字段。
字段 说明
id 患者id
患者表所有字段

4.2 每个时期的若干小表

存储基本信息,关键是外键是主表的id。

字段 说明
id 唯一id
所有数据字段

4.3 流程节点表

主要是绑定主表,还可以添加一个时期的额外数据,比如一个时期的表单填写提示。

字段 说明
id 唯一id
master_table 主表名称
权限控制相关字段
该时期的其它数据字段

4.4 工作流表

在工作流表中绑定多个工作节点有两种方式:

  • 1.根据最多节点数目设置若干个节点字段,存储流程节点的id。
  • 2.设置一个字段,字符串拼接的形式,存储所有流程节点id。

同样,两种方式各有好处:

  • 使用第1种方式,需要需求中最多节点个数完全确定,才方便设计合适的字段。
  • 使用第2种方式,可以存储任意个节点,但在拿出处理的时候有些麻烦。

一个字段模式

字段 说明
id 唯一id
process_name 工作流名称
process_des 工作流描述
process_ndoes 所有节点id
权限控制相关的其它字段

多个字段模式

  • 其中哈希值主要用来工作流判重。
字段 说明
id 唯一id
process_name 工作流名称
process_des 工作流描述
node_num 节点数目
process_hash 工作流哈希值
node1 节点1
node2 节点2
node3 节点3
若干节点
权限控制相关的其它字段

4.5 患者表

患者表中和流程相关的一共三个字段:工作流id,当前节点id,下一节点id。其中存储下一节点id的做法类似单链表。

字段 说明
id 唯一id
process_id 工作流id
current_node_id 当前节点id
next_node_id 下一节点id
所有数据字段

5.接口设计

5.1 针对工作流节点的接口

  • 1.新增工作流节点。

    • 需要保证工作流节点所绑定的主表id和名称是唯一的。
  • 2.修改工作流节点。

    • 如果修改了工作流绑定的主表,先要判断这个节点所在工作流是否被患者绑定,如果绑定了,那么将无法修改主表。
  • 3.删除工作流节点。

    • 需要保证该节点未绑定任何工作流。
  • 4.查询工作流节点。

    • 查询该节点的所有数据。

5.2 针对工作流的接口

  • 1.新增工作流。

    • 需要保证工作流节点不重复,重复就会出错。
    • 需要保证节点数大于0.
    • 需要保证整条节点链表不重复。
    • 如果是多字段模式的,还需要检验是否依次填写节点。
  • 2.修改工作流。

    • 如果已经有患者绑定了工作流,那么将不能修改工作流的节点。
  • 3.删除工作流。

    • 如果已经有患者绑定了工作流,那么将不能删除工作流的节点。
  • 4.查询工作流。

    • 查询工作流的所有字段。

5.3 针对患者的接口

  • CRUD操作略。

  • 查询患者流程信息。

    • 需要获取患者所处流程的所有节点信息。
    • 需要判断哪些节点已经完成,正处于哪个节点,哪些节点还未到达。
  • 患者流程通过。

    • 患者的信息将会插入下一节点对应的主表。
    • 修改患者当前节点,下一节点。

6. 前端页面设计

6.1 针对化患者信息处

  • 在操作一栏中能够处理患者的流程。
    在这里插入图片描述

6.2 患者流程处理处

在这里插入图片描述

6.3 具体时期处

在这里插入图片描述

7.其它

这种表单式工作流的设计,理论上是可以抽取出来成为一个独立的框架,待日后有时间精力再去尝试。


ATFWUS 2021-08-26

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ATFWUS/article/details/119929887

智能推荐

python全栈开发—函数再战—实现模块化设计_全栈开发与数学-程序员宅基地

文章浏览阅读256次。函数再战—熟练基础,精通技能,触类旁通之所以又整理了一遍函数,主要是因为当我进行后续学习的时候,发现函数比想象的要NB的多,于是又厚着脸皮又来了一遍,嗯,果然很NB。建议在学习的过程中遇到了难题,记得回头复习复习,也许正是那些你忽略的内容,给未来的你营造出自己是SB的难题。内容概括:函数基本语法及特性函数与局部变量返回值嵌套函数递归匿名函数函数式编程介绍高阶函数内置函数..._全栈开发与数学

在vs开发环境中用opencv读取图片,Debug模式下成功,release模式下失败的可能原因_visual studio的debug模式可以include opencv release模式不行-程序员宅基地

文章浏览阅读921次。1 检查一下release模式下的链接器的输入,其依赖的lib名称最后一个字母是没有"d",d代表debug如图:2 检查一下路径,看是否因为带中文的路径导致编码错误..._visual studio的debug模式可以include opencv release模式不行

教你一步一步使用Excel获取API接口的金融数据_excel的api key-程序员宅基地

文章浏览阅读5.6k次,点赞7次,收藏26次。在用EXCEL做量化分析的时候,经常需要通过一些金融数据平台的API接口,获取各种数据。最常用的公共API接口有Yahoo Finance,Google Finance,新浪财经,搜狐财经等。这些都不需要注册,就可以直接使用。获取方式相对简单,但数据种类不够丰富,通常只包括交易数据和财务数据。另外一些免费的金融数据平台,如国外的Quandl和国内的Tushare也都提供了API接口,数据种类更..._excel的api key

ThinkPHP去除url中的index.php,绝对管用!-程序员宅基地

文章浏览阅读1.6k次。例如你的原路径是 http://localhost/test/index.php/index/add那么现在的地址是 http://localhost/test/index/add如何去掉index.php呢?1.httpd.conf配置文件中加载了mod_rewrite.so模块 //在APACHE里面去配置#LoadModule rewrite_module modu

Qt核心机制与原理_qt原理-程序员宅基地

文章浏览阅读3.8k次,点赞5次,收藏39次。★了解Qt和C++的关系★掌握Qt的信号/槽机制的原理和使用方法★了解Qt的元对象系统★掌握Qt的架构★理解Qt的事件模型,掌握其使用的时机信号与槽、元对象系统、事件模型是Qt机制的核心,如果您想要掌握Qt编程,就需要对它们有比较深入的了解。本章重点介绍了信号与槽的基本概念和用法、元对象系统、Qt的事件模型,以及它们在实际使用过程中应注意的一些问题。Qt对标准C++的扩展标准C++对象模型为面向对象编程提供了有效的实时支持,但是它的静态特性在一些领域中表现的不够灵活。事实上,GUI应用程序_qt原理

CC2640R2F BLE5.0 TI-RTOS概述_ti rtos 总中断-程序员宅基地

文章浏览阅读8.2k次,点赞3次,收藏25次。TI-RTOS概述TI-RTOS是CC2640R2F设备上蓝牙低能耗项目的运行环境。TI-RTOS内核是传统SYS/BIOS内核的定制版本,可作为具有驱动程序,同步和调度工具的实时抢占式多线程操作系统。线程模块TI-RTOS内核管理线程执行的四个不同的任务级别,如图21所示。线程模块列表如下图所示,按照优先级降序排列。硬件中断软件中断任务后台空闲功能的空闲任务_ti rtos 总中断

随便推点

爬虫框架 - feapder_feapder 网盘-程序员宅基地

文章浏览阅读1.0k次。1. 前言众所周知,Python 最流行的爬虫框架是 Scrapy,它主要用于爬取网站结构性数据今天推荐一款更加简单、轻量级,且功能强大的爬虫框架:feapder项目地址:https://github.com/Boris-code/feapder2. 介绍及安装和 Scrapy 类似,feapder 支持轻量级爬虫、分布式爬虫、批次爬虫、爬虫报警机制等功能内置的 3 种爬虫如下: AirSpider 轻量级爬虫,适合简单场景、数据量少的爬虫 Spider._feapder 网盘

《数据结构与算法分析:Java语言描述》.pdf-程序员宅基地

文章浏览阅读6k次,点赞2次,收藏6次。关注“Java后端技术全栈”回复“面试”获取全套大厂面试资料程序=数据结构+算法这好比是软件工程师的“武林秘籍”。数据结构指的是数据与数据之间的逻辑关系;算法指的是解决特定问题的步骤和方..._数据结构与算法分析java语言描述pdf

PyTorch——自注意力(self-attention)机制实现(代码详解)_自注意力机制代码-程序员宅基地

文章浏览阅读8w次,点赞111次,收藏691次。参考链接https://www.bilibili.com/video/BV1JE411g7XF?p=54https://arxiv.org/abs/1706.03762https://blog.csdn.net/qq_36653505/article/details/83375160简述自注意力机制(self-attention)self-attention可以视为一个特征提取层,给定输入特征a1,a2,⋅⋅⋅ana^{1},a^{2},\cdot \cdot \cdot a^{n}a1,a2_自注意力机制代码

在Vue中应用cornerstone并且实时更新缩放比例等数据_浏览器缩放倍数变化时 更新数据 vue-程序员宅基地

文章浏览阅读1.6k次。在Vue中应用cornerstone并且跟随dicom实时更新缩放比例等数据最近需要在cornerstone的显示界面中显示一些数据,比如缩放比例以及渲染时间等,但是这些是需要根据鼠标事件进行实时更新的,想想肯定是有这个接口的,于是便试了一下。1、获取到当前视窗的对象获取到视窗这个对象因为它里面肯定会有许多属性可以直接被使用,刚好我们的缩放比例就是里面的scale,还有一些属性可以直接取用。..._浏览器缩放倍数变化时 更新数据 vue

C语言中常用的函数_c语言常用函数-程序员宅基地

文章浏览阅读3.1w次,点赞135次,收藏1k次。C语言中常用的函数1、putchar()函数2、getchar()函数3、pow( a , b )函数4、sqrt( a )函数5、fabs(a)函数6、puts(字符数组)函数——输出字符串的函数7、gets(字符数组)——输入字符串的函数8、strcat(a , b)函数——字符串连接函数9、strcpy函数——字符串复制函数10、strncpy函数——字符串复制函数11、strcmp函数——字符串比较函数12、strlen函数——测量字符串长度的函数13、strlwr函数——转换为小写的函数14、_c语言常用函数

webpack打包时如何修改文件名_webpack打包文件名称设置-程序员宅基地

文章浏览阅读5k次。webpack打包时如何修改文件名在使用webpack进行项目打包的时候,我们可通过以下方式对不同类型的资源,进行文件名或文件路径的修改_webpack打包文件名称设置

推荐文章

热门文章

相关标签