动态表单存储设计


动态表单存储设计

前言

Flowable, Activiti 等开源解决方案所提供的表单引擎是没有业务表单数据持久化的功能(即自动创建表,将表单数据持久化功能),只提供动态表单创建以及渲染功能。目前来看表单引擎服务主要功能如下:

  • 动态表单配置以及渲染(主要在于前端实现)
  • 表单数据库持久化

以下是目前实现业务表单数据持久化的几种方案:

以下方案都以请假流程的表单为例,比较简单就请假天数(days)以及请假理由(reason),动态表单如下所示:

动态表单存储设计

方案一:动态添加字段

一个表单对应数据库的一张或多张物理表(主从表)

针对请假流程如何操作呢?给请假流程表单创建一张数据表,包含字段 days  以及 reason 。其他业务表单也是如此操作。

SQL 全选
create table leave_data
(
	days int default 0 null comment '请假天数',
	reason varchar(250) null comment '请假理由'
)
comment '请假流程业务数据';

该方案存在的问题:

  • 一个表单对应数据库的一张或多张物理表,随着业务的增多,数据库的物理表会不断膨胀。
  • 业务表单字段需要修改时(比如给请假流程添加一个开始时间字段,就需要调整物理表结构),其对应的物理表结构也需要修改,在物理表很多数据时,改变物理表scheme会锁表。

方案二:预留空白字段,动态分配

业务数据存储表:

SQL 全选
create table data
(
  name varchar(250) null comment '业务表单名',
	field_0 varchar(250) null comment '字段0',
	field_1 varchar(250) null comment '字段1',
	field_2 varchar(250) null comment '字段2',
	field_3 varchar(250) null comment '字段3'
)
comment '业务数据';

业务表单属性表:

SQL 全选
create table table_config
(
	name varchar(250) null comment '表单名',
	field_name varchar(250) null comment '字段名',
  field_map varchar(250) null comment '字段映射'
)
comment '表配置';

实际操作下来,存储是这样哒:

动态表单存储设计

动态表单存储设计

那么动态字段变更需要修改表字段配置表即可。

缺点:

  • 操作数据的时候都需要先去 map 中转以下才能查询(程序层面可以解决)
  • 如果一张业务表保存所有的数据话,不利于优化(可以进行扩展,配置多张业务表,不过这样也可能会出现方案一中物理表爆炸的问题)

方案三:属性使用 KEY/VALUE 格式存储

将表单数据全部都用 Key/Value 的格式来存储。参考如下:

SQL 全选
create table attributes
(
  f_id varchar(250) null comment '关联id',
	key varchar(250) null comment '属性',
	value varchar(250) null comment '属性值',
	field_2 varchar(250) null comment '字段2',
	field_3 varchar(250) null comment '字段3'
)
comment '属性';

具体操作后即是:

动态表单存储设计

动态添加属性字段只需要添加 Key/value。题外话,reddit 的数据库就两张表,也是这样的设计方案,不过现在已经改掉了,成为历史。

缺点:

  • 不太好支持关联子表
  • 程序中处理取值不方便

方案四:MongoDB 方案设计

MongoDB 方案的话,只需要将前端发过来的JSON写入即可,这里还是以请假流程为例:

动态表单存储设计

集合内数据允许动态添加字段:

动态表单存储设计

集合类似于关系型数据库中的表,可以存储不规则的数据,只能说 Mongodb 擅长干这种事情。

总结

以上方案设计生产环境使用还需要改进使用,目前市面上用的多得应该是方案二,MongoDB 也是一个不错选项,仅在数据持久化这块,具体业务场景下使用 MongoDB + 关系型数据库的设计也可以是一个备选的方案。

 

参考来源:动态表单存储设计 - AT_HUAZI - 博客园 (cnblogs.com)

版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
管理员
上一篇:web开发 Table增加全选
下一篇:JQuery将form表单转换为json,并提交后台处理
评论列表

发表评论

评论内容
昵称:
关联文章

动态存储设计
.NET SAAS 架构与设计 -SqlSugar ORM
html禁止浏览器对form自动填充
如何在 SQL Server 中按照修改时间排序获取最新更改的存储过程
JQuery将form转换为json,并提交后台处理
查询-前端页面开发
.NET C#教程初级篇 1-1 基本数据类型及其存储方式
element-ui改进el-form样式,取消form-item底部的边距:form-inner-error
YESWin开发框架权限设计相关结构说明
API接口安全设计方案
主从表演练之采购2-个性化调整
陈幼坚设计蓝月亮标识
基础字典管理功能开发-结构设计,模型更新和数据库迁移脚本生成
主从表演练之采购
查询-后台API开发
C# 编写一个小而快的 Windows 动态桌面
javascriptForm转json进行ajax提交Jqueryjson提交
.NET 通用多条件动态参数查询方法 - SqlSugar ORM
.NET Core 利用委托实现动态流程组装
Sql Server 查看存储过程最后修改时间

联系我们
联系电话:15090125178(微信同号)
电子邮箱:garson_zhang@163.com
站长微信二维码
微信二维码