CN108037916A - 一种基于web的图形化业务建模方法 - Google Patents

一种基于web的图形化业务建模方法 Download PDF

Info

Publication number
CN108037916A
CN108037916A CN201711227058.XA CN201711227058A CN108037916A CN 108037916 A CN108037916 A CN 108037916A CN 201711227058 A CN201711227058 A CN 201711227058A CN 108037916 A CN108037916 A CN 108037916A
Authority
CN
China
Prior art keywords
business
database
business object
relation
web
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201711227058.XA
Other languages
English (en)
Other versions
CN108037916B (zh
Inventor
李李
郑才海
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fuzhou Zhi Jie Mdt Infotech Ltd
Original Assignee
Fuzhou Zhi Jie Mdt Infotech Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Fuzhou Zhi Jie Mdt Infotech Ltd filed Critical Fuzhou Zhi Jie Mdt Infotech Ltd
Priority to CN201711227058.XA priority Critical patent/CN108037916B/zh
Publication of CN108037916A publication Critical patent/CN108037916A/zh
Application granted granted Critical
Publication of CN108037916B publication Critical patent/CN108037916B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/31Programming languages or programming paradigms
    • G06F8/315Object-oriented languages
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/34Graphical or visual programming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/35Creation or generation of source code model driven

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供一种基于web的图形化业务建模方法,设计业务模型的存储文件的存储结构和存储格式,该存储结构由业务对象及业务对象之间的关系构成,每个业务模型的存储文件分别对应唯一的数据库,每个业务对象对应数据库中的一张表,每个业务对象属性对应数据库表的字段,业务对象之间的关系对应数据库表之间的关联关系;通过Web拖拽方式配置业务模型,包括业务对象、业务对象之间的关系及业务对象属性,配置好的业务模型保存为存储文件,该存储文件的内容即为业务模型的配置信息;最后将业务模型同步至数据库。本发明本方法实现业务建模的拖拽设计方式,然后同步生成到数据库的表结构,并且支持增量更新数据库的表结构。

Description

一种基于web的图形化业务建模方法
技术领域
本发明涉及一种业务建模方法,尤其涉及了web的建模方法。
背景技术
在web软件开发过程中,根据客户需求转为业务模型是软件开发过程的一个必要步骤,最后转为数据库的表结构。
软件产品是一个复杂过程的产物,从软件需求、设计、开发、测试以及部署发布一整个过程才能完成,其中从软件需求到软件设计是很重要的一步。业务模型是软件设计根据需求设计的一张表或多张表及表与表之间的关系,设计完成后生成SQL建库脚本,导入到数据库。
目前市面上的工具大多数是C/S软件,能方便的完成模型设计,导出数据库脚本,但是导出的脚本都是全量的脚本,不能增量的进行导出数据库脚本,这样的脚本不适合更新,特别对低版本软件数据库升级的时候执行不成功;另外,在软件不断升级改造及过程,很多不规范的操作会导致版本库中的模型与实际数据库的表结构不一致,加大了软件更新升级和软件版本管理的难度和复杂度。
发明内容
本发明要解决的技术问题,在于提供一种基于web的图形化业务建模方法,本方法实现业务建模的拖拽设计方式,然后同步生成到数据库的表结构,并且支持增量更新数据库的表结构。
本发明是这样实现的:步骤S1、设计业务模型的存储文件的存储结构和存储格式,该存储结构由业务对象及业务对象之间的关系构成,业务对象又由业务对象属性构成,每个业务模型的存储文件分别对应唯一的数据库,每个业务对象对应数据库中的一张表,每个业务对象属性对应数据库表的字段,业务对象之间的关系对应数据库表之间的关联关系;
步骤S2、通过Web拖拽方式配置业务模型,包括业务对象、业务对象之间的关系及业务对象属性,配置好的业务模型保存为存储文件,该存储文件的内容即为业务模型的配置信息;
步骤S3、将业务模型同步至数据库,包括:
(1)通过JDBC读取已存在的数据库结构,并在内存缓存中存储为Map;
(2)遍历业务模型的数据文件的业务模型配置信息,与数据库结构进行比对,判断是否存在有新增或变更的数据库表,表字段或数据库表之间的关系,若存在,则生成新增或更新的SQL语句;
(3)通过JDBC执行所述新增或更新的SQL语句完成数据库的更新。
进一步的,所述业务对象属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象;
所述业务对象配置信息属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象,其中外键对象保存的信息是外键对应的表及对应的主键字段;业务对象与对象的关系使用属性中的外键对象关联,从而实现业务对象对应的数据表与表之间的关联。
进一步的,所述通过Web拖拽方式配置业务模型具体是:使用浏览器的SVG矢量图功能,把每个业务对象及业务对象之间关系的配置信息展现在web中,使用HTML的DIV+CSS展现业务对象和业务对象之间关系的信息;业务对象之间的关系使用有箭头方式的连线进行连接,箭头的指向方式表示被关联的业务对象;
业务模型设计完并保存后,遍历页面上的各个业务对象形成的表结构信息数组,并根据所述连线建立外键关系数组,然后将表结构信息数组和外键关系数组提交到后台。
进一步的,所述后台根据页面提交的信息生成实体类对象,该实体类对象使用Java自带的编译工具类编译成实体类class,调用开源工具包Hibernate的tool类,根据业务模型配置对应的数据库类型以及版本,生成数据库创建脚本或更新的脚本;最后使用对应的数据库JDBC执行数据库脚本,完成业务模型与数据库的同步功能。
进一步的,所述业务模型的存储文件为JSON格式或XML格式。
本发明具有如下优点:
1、支持使用web浏览器进行业务模型设计,方便开发人员和业务设计人员查看;
2、支持保存模型设计时即可把设计的模型同步到运行的数据库,实现一键同步数据库;
3、支持数据库表结构增量升级,极大的方便软件升级和更新。
附图说明
下面参照附图结合实施例对本发明作进一步的说明。
图1为本发明方法通过Web拖拽设计业务模型的状态图。
图2为本发明方法配置业务对象属性的状态图。
具体实施方式
本发明的基于web的图形化业务建模方法,包括:
步骤S1、设计业务模型的存储文件的存储结构和存储格式,该存储结构由业务对象及业务对象之间的关系构成,业务对象又由业务对象属性构成,每个业务模型的存储文件分别对应唯一的数据库,每个业务对象对应数据库中的一张表,每个业务对象属性对应数据库表的字段,业务对象之间的关系对应数据库表之间的关联关系;
所述业务对象属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象;
所述业务对象配置信息属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象,其中外键对象保存的信息是外键对应的表及对应的主键字段;业务对象与对象的关系使用属性中的外键对象关联,从而实现业务对象对应的数据表与表之间的关联。从而实现业务对象对应的数据表与表之间的关联(可以是1对1,1对多和多对多的关系)
步骤S2、通过Web拖拽方式配置业务模型,包括业务对象、业务对象之间的关系及业务对象属性,配置好的业务模型保存为存储文件,可以保存为JSON文件或XML文件或txt文件,该存储文件的内容即为业务模型的配置信息;
具体过程如图1所示:使用浏览器的SVG矢量图功能,把业务模型中每个业务对象及业务对象之间关系的配置信息展现在web中,如图中右侧的窗口;使用HTML的DIV+CSS展现业务对象及对象与对象之间关系的信息,图中右侧的窗口中每个方框表示一个业务对象;通过图中左侧的窗口的管理模块(图中实施例中包括系统参数配置表、职务定义表、用户组等业务对象)即可将各业务模型的业务对象通过Web拖拽拉到右侧的窗口中进入设计,业务对象的关系使用有箭头方式的连线进行连接,箭头的指向方式表示被关联的业务对象。配置业务对象属性时,如图2所示,在相应栏目配置属性信息保存即可。当业务模型设计完并保存后,遍历页面上的各个业务对象形成的表结构信息数组,并根据所述连线建立外键关系数组,然后将表结构信息数组和外键关系数组一并提交到后台。
S3、将业务模型同步至数据库,包括:
(1)通过JDBC读取数据库的库表结构,并在内存缓存中存储为Map;
(2)遍历业务模型的数据文件的业务模型配置信息,与数据库结构进行比对,判断是否存在有新增或变更的数据库表,表字段或数据库表之间的关系,若存在,则生成新增或更新的SQL语句;具体是:所述后台根据页面提交的业务模型之配置文件生成实体类对象,该实体类对象使用Java自带的编译工具类编译成实体类class,调用开源工具包Hibernate的tool类,根据业务模型配置对应数据库类型以及版本,生成新增或更新的SQL语句,即数据库创建脚本或更新的脚本;
(3)最后使用对应的数据库JDBC执行数据库脚本即所述新增或更新的SQL语句,完成业务模型与数据库的同步功能。
综上所述,本发明实现业务建模的拖拽设计方式,然后同步生成到数据库的表结构,并且支持增量更新数据库的表结构。支持使用浏览器进行web业务模型设计,方便开发人员和业务涉及人员查看,支持保存模型设计可实现一键同步数据库;支持增量的数据库表结构升级,极大的方便软件升级和更新。
虽然以上描述了本发明的具体实施方式,但是熟悉本技术领域的技术人员应当理解,我们所描述的具体的实施例只是说明性的,而不是用于对本发明的范围的限定,熟悉本领域的技术人员在依照本发明的精神所作的等效的修饰以及变化,都应当涵盖在本发明的权利要求所保护的范围内。

Claims (5)

1.一种基于web的图形化业务建模的方法,其特征在于:
步骤S1、设计业务模型的存储文件的存储结构和存储格式,该存储结构由业务对象及业务对象之间的关系构成,业务对象又由业务对象属性构成,每个业务模型的存储文件分别对应唯一的数据库,每个业务对象对应数据库中的一张表,每个业务对象属性对应数据库表的字段,业务对象之间的关系对应数据库表之间的关联关系;
步骤S2、通过Web拖拽方式配置业务模型,包括业务对象、业务对象之间的关系及业务对象属性,配置好的业务模型保存为存储文件,该存储文件的内容即为业务模型的配置信息;
步骤S3、将业务模型同步至数据库,包括:
(1)通过JDBC读取已存在的数据库结构,并在内存缓存中存储为Map;
(2)遍历业务模型的数据文件的业务模型配置信息,与数据库结构进行比对,判断是否存在有新增或变更的数据库表,表字段或数据库表之间的关系,若存在,则生成新增或更新的SQL语句;
(3)通过JDBC执行所述新增或更新的SQL语句完成数据库的更新。
2.如权利要求1所述的一种基于web的图形化业务建模的方法,其特征在于:所述业务对象的属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象;
所述业务对象配置信息的列属性包含:编号、名称、类型、长度、默认值、是否主键、是否外键、是否可空、是否为空、备注以及外键对象,其中外键对象保存的信息是外键对应的表及对应的主键字段;业务对象与对象的关系使用属性中的外键对象关联,从而实现业务对象对应的数据表与表之间的关联。
3.如权利要求1所述的一种基于web的图形化业务建模的方法,其特征在于:所述通过Web拖拽方式配置业务模型具体是:使用浏览器的SVG矢量图功能,把每个业务对象及业务对象之间关系的配置信息展现在web中,使用HTML的DIV+CSS展现业务对象和业务对象之间关系的信息;业务对象之间的关系使用有箭头方式的连线进行连接,箭头的指向方式表示被关联的业务对象;
业务模型设计完并保存后,遍历页面上的各个业务对象形成的表结构信息数组,并根据所述连线建立外键关系数组,然后将表结构信息数组和外键关系数组提交到后台。
4.如权利要求3所述的一种基于web的图形化业务建模的方法,其特征在于:所述后台根据页面提交的信息生成实体类对象,该实体类对象使用Java自带的编译工具类编译成实体类class,调用开源工具包Hibernate的tool类,根据业务模型配置对应的数据库类型以及版本,生成数据库创建脚本或更新的脚本;最后使用对应的数据库JDBC执行数据库脚本,完成业务模型与数据库的同步功能。
5.如权利要求1所述的一种基于web的图形化业务建模的方法,其特征在于:所述业务模型的存储文件为JSON格式或XML格式。
CN201711227058.XA 2017-11-29 2017-11-29 一种基于web的图形化业务建模方法 Active CN108037916B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711227058.XA CN108037916B (zh) 2017-11-29 2017-11-29 一种基于web的图形化业务建模方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711227058.XA CN108037916B (zh) 2017-11-29 2017-11-29 一种基于web的图形化业务建模方法

Publications (2)

Publication Number Publication Date
CN108037916A true CN108037916A (zh) 2018-05-15
CN108037916B CN108037916B (zh) 2021-03-30

Family

ID=62094763

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711227058.XA Active CN108037916B (zh) 2017-11-29 2017-11-29 一种基于web的图形化业务建模方法

Country Status (1)

Country Link
CN (1) CN108037916B (zh)

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110399374A (zh) * 2019-07-05 2019-11-01 东软集团股份有限公司 数据检索方法、装置、存储介质及电子设备
CN110516010A (zh) * 2019-08-28 2019-11-29 浪潮软件集团有限公司 一种基于邻接表的数据库实体关系模型提取方法及装置
CN110941422A (zh) * 2019-11-21 2020-03-31 山东鲁能软件技术有限公司 代码自动生成方法、代码生成器及可读存储介质
CN111104409A (zh) * 2019-12-25 2020-05-05 上海米哈游天命科技有限公司 一种数据库处理方法、装置、存储介质及电子设备
CN111191041A (zh) * 2019-11-22 2020-05-22 腾讯云计算(北京)有限责任公司 特征数据获取方法、数据存储方法、装置、设备及介质
CN111291025A (zh) * 2020-03-10 2020-06-16 北京东方金信科技有限公司 逻辑模型支持多物理模型转换的方法及存储设备
CN111752546A (zh) * 2020-06-30 2020-10-09 武汉虹信技术服务有限责任公司 一种基于Excel的数据库对象设计管理平台、系统及方法
CN111913949A (zh) * 2019-05-07 2020-11-10 北京京东尚科信息技术有限公司 数据处理方法、系统、装置和计算机可读存储介质
CN112487006A (zh) * 2020-11-30 2021-03-12 山东浪潮通软信息科技有限公司 一种动态编辑数据结构并生成数据库表的实现方法
CN112765712A (zh) * 2021-01-20 2021-05-07 广联达科技股份有限公司 Bim数据的结构化管理方法、装置、计算机设备及存储介质
CN113885894A (zh) * 2021-09-15 2022-01-04 南京海泰医疗信息系统有限公司 一种基于电子病历产品后台的打包和更新方法和系统
CN115712413A (zh) * 2022-11-15 2023-02-24 广东中设智控科技股份有限公司 低代码开发方法、装置、设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090183092A1 (en) * 2007-10-03 2009-07-16 Britesoft Solutions (M) Sdn Bhd Customizable application system
CN104252506A (zh) * 2013-06-28 2014-12-31 易保网络技术(上海)有限公司 同步构建业务模型和数据仓库模型及其映射的方法及系统
CN106844385A (zh) * 2015-12-07 2017-06-13 北京航天长峰科技工业集团有限公司 一种结合Spark技术构建灵活业务模型的方法
CN107169022A (zh) * 2017-04-07 2017-09-15 广东精点数据科技股份有限公司 一种实现数据仓库自动建模的系统及方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090183092A1 (en) * 2007-10-03 2009-07-16 Britesoft Solutions (M) Sdn Bhd Customizable application system
CN104252506A (zh) * 2013-06-28 2014-12-31 易保网络技术(上海)有限公司 同步构建业务模型和数据仓库模型及其映射的方法及系统
CN106844385A (zh) * 2015-12-07 2017-06-13 北京航天长峰科技工业集团有限公司 一种结合Spark技术构建灵活业务模型的方法
CN107169022A (zh) * 2017-04-07 2017-09-15 广东精点数据科技股份有限公司 一种实现数据仓库自动建模的系统及方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
JONLLEN PENG: "使用PowerDesigner的建模创建升级管理数据库", 《博客园,HTTPS://WWW.CNBLOGS.COM/JONLLEN/ARCHIVE/2009/07/13/POWERDESIGNER.HTML》 *

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111913949A (zh) * 2019-05-07 2020-11-10 北京京东尚科信息技术有限公司 数据处理方法、系统、装置和计算机可读存储介质
CN111913949B (zh) * 2019-05-07 2023-09-01 北京京东振世信息技术有限公司 数据处理方法、系统、装置和计算机可读存储介质
CN110399374A (zh) * 2019-07-05 2019-11-01 东软集团股份有限公司 数据检索方法、装置、存储介质及电子设备
CN110516010A (zh) * 2019-08-28 2019-11-29 浪潮软件集团有限公司 一种基于邻接表的数据库实体关系模型提取方法及装置
CN110516010B (zh) * 2019-08-28 2023-06-09 浪潮软件集团有限公司 一种基于邻接表的数据库实体关系模型提取方法及装置
CN110941422A (zh) * 2019-11-21 2020-03-31 山东鲁能软件技术有限公司 代码自动生成方法、代码生成器及可读存储介质
CN110941422B (zh) * 2019-11-21 2023-08-15 山东鲁能软件技术有限公司 代码自动生成方法、代码生成器及可读存储介质
CN111191041A (zh) * 2019-11-22 2020-05-22 腾讯云计算(北京)有限责任公司 特征数据获取方法、数据存储方法、装置、设备及介质
CN111104409A (zh) * 2019-12-25 2020-05-05 上海米哈游天命科技有限公司 一种数据库处理方法、装置、存储介质及电子设备
CN111291025A (zh) * 2020-03-10 2020-06-16 北京东方金信科技有限公司 逻辑模型支持多物理模型转换的方法及存储设备
CN111752546A (zh) * 2020-06-30 2020-10-09 武汉虹信技术服务有限责任公司 一种基于Excel的数据库对象设计管理平台、系统及方法
CN112487006A (zh) * 2020-11-30 2021-03-12 山东浪潮通软信息科技有限公司 一种动态编辑数据结构并生成数据库表的实现方法
CN112765712A (zh) * 2021-01-20 2021-05-07 广联达科技股份有限公司 Bim数据的结构化管理方法、装置、计算机设备及存储介质
CN113885894A (zh) * 2021-09-15 2022-01-04 南京海泰医疗信息系统有限公司 一种基于电子病历产品后台的打包和更新方法和系统
CN113885894B (zh) * 2021-09-15 2023-12-12 南京海泰医疗信息系统有限公司 一种基于电子病历产品后台的打包和更新方法和系统
CN115712413A (zh) * 2022-11-15 2023-02-24 广东中设智控科技股份有限公司 低代码开发方法、装置、设备及存储介质
CN115712413B (zh) * 2022-11-15 2024-04-19 广东中设智控科技股份有限公司 低代码开发方法、装置、设备及存储介质

Also Published As

Publication number Publication date
CN108037916B (zh) 2021-03-30

Similar Documents

Publication Publication Date Title
CN108037916A (zh) 一种基于web的图形化业务建模方法
US10606573B2 (en) System and method for computer language migration using a re-architecture tool for decomposing a legacy system and recomposing a modernized system
US10698594B2 (en) System for providing dynamic linked panels in user interface
CN104133772B (zh) 一种自动生成测试数据的方法
US5745878A (en) Business requirement handling apparatus
KR102229010B1 (ko) 데이터를 모델링하기 위한 시스템 및 방법
CN103246733A (zh) 一种基于元数据的动态表单系统及其生成方法
US8010905B2 (en) Open model ingestion for master data management
US20160170719A1 (en) Software database system and process of building and operating the same
CN106951228A (zh) 版本迭代中差异的处理方法和装置
CN101706716A (zh) 基于vo的表单定制配置与解析运行方法
CN106598612A (zh) 一种数据库中数据表的操作方法及系统
EP2107457B1 (en) Automatic software configuring system
US20160259831A1 (en) Methodology supported business intelligence (BI) software and system
CN107291471A (zh) 一种支持可定制化数据采集的元模型框架系统
CN108228223A (zh) 基于国产cpu环境的多类型数据库统一增量更新方法
US20110153562A1 (en) Error prevention for data replication
US8301661B2 (en) Generic information system builder and runner
Biermann et al. Lifting parallel graph transformation concepts to model transformation based on the eclipse modeling framework
US6915313B2 (en) Deploying predefined data warehouse process models
CN101901262A (zh) 基于面向对象模型的企业建库和业务数据显示的方法
CN103488738A (zh) 一种自动实现java对象及数据表sql文件的方法及系统
CN112652371A (zh) 一种用于智慧医疗领域的护理文书设计器及生成装置
CN109542438A (zh) 一种基于可视化的图表开发方法
CN103927402A (zh) 一种控制逻辑图模块化设计管理系统实现方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
CB02 Change of applicant information

Address after: Room 513, building 11, area B, Fuzhou Software Park, 89 software Avenue, Gulou District, Fuzhou City, Fujian Province 350000

Applicant after: Yousuyun (Fujian) Technology Co.,Ltd.

Address before: Room 513, building 11, area B, Fuzhou Software Park, 89 software Avenue, Gulou District, Fuzhou City, Fujian Province 350000

Applicant before: FUZHOU ZHIJIE INFORMATION TECHNOLOGY Co.,Ltd.

CB02 Change of applicant information
GR01 Patent grant
GR01 Patent grant