♾好好与这个世界对话:gMIS/吉密斯更新+扩展操作行为

距离上次gMIS/吉密斯的更新差不都有半年过去了,这期间gMIS部署和使用的场景进一步扩大。最近又有新的部署并使用,在更新维护的同时,也有增加新功能,比如这次比较重要的一点是进一步地深化和加强了扩展行为操作的使用。情况较复杂,兹详述如下,以备忘。

gMIS/吉密斯 是“通用管理信息系统“软件,当我们有底气说“通用”的时候,意味着这个系统可以管理任何基于关系数据库所管理的数据,为这些数据提供面向非技术人员的人性化的操作和使用数据的途径。关系数据库,技术人员能耳熟能详地列出 Oracle、MySQL、SQLServer、SyBase等,其也是当今信息化的基础设施之一。通用的面向技术人员的,各种数据库的客户端,无论是基于命令行的还是基于GUI的(包括App和Web, 如 Navicat、PHPMyAdmin等),都有不少选择。而能够基于原始数据,直接产生能够面向非技术人员的,类似产品并不多,我们说“通用”,是我们创建了一套方法,可以针对任意指定的“字段”,无论其什么数据类型,我们都能够在gMIS/吉密斯中配置出契合其特点的输出/输入接口/界面,也即我们的 extra目录,插件式的工作,通过指定配置信息,无论这个字段是读写数据、字符串、选择项、文件、层级目录、编辑器等,均能应付自如。当一种新的数据类型、接口、界面被需要时,我们可以再通过extra方式制作并嵌入进去,这就是当我们说“通用”的底气。

一直以来,gMIS/吉密斯秉持这种“通用性”工作良好。

然而,我们深知,多样性、丰富性和复杂性才是世界的本原,我们以“通用”立命题就有某种抗自然规律的冲动,这种带有某种邪乎劲的要“包治百病”式的做法,会让人担忧,也令人不解。毕竟,这世界上没有包治百病的良药。


Fig.1 数据库数据表示层级

深度地解析,上述“通用性”是建立在对“字段”这一级别的操作上,也即,可以应对所有数据类型的字段进行操作,按照通常的数据组织结构划分 “数据库 — 数据表 — 记录 — 字段”(Fig.1),我们实现了在“字段”级的“通用性”操作。

如果多样性和丰富性的需要是针对“记录(Row)”这一级别呢?

目前针对“记录”的操作,我们有规定的动作“add、modify、view、print、delete、search(insite, pickup)、pivot、export、copy”等,如果要增加一种或多种针对“记录”的操作,该如何操作?这种需求合理吗?常见吗? 需要被满足吗? 能被满足吗? 如果能,该如何实现在“记录”层级的“通用性”?

最早我们设想,几乎所有共用的操作,针对一条数据(Row)的操作也就这么多,除了增删改查这四项基本的,我们已经很丰富地增强提供了其他多项。然而,诚如前所言,多样、丰富和复杂的客观世界,可能会有更多种针对一条数据的操作需求。这种需求是合理的,也是客观的描绘世界的必需项。这样的设计应该被满足。

初次遇到这样的需求,并令我们面对和思考这样的问题是在进行 工作流 的设计和制作上。工作流的本质也是对Row为单位的数据进行操作,但其动作已经超过了对Row本身的操作,而是Row之间发生了关系,也即一条Row可能从用户A流转到用户B,然后用户B将该Row流转到用户C等等,依此类推,而且还可能针对Row产生不同的修改。

为了满足这种需求,我们设计并实现了第一版的 ActOption 标记,这一个版本的 ActOption 在数据表的 table节点配置,并输出绑定到 act/view 界面上. 详细记录参考:
[2016] -gMIS 更新多库连接及工作流workflow
[
2018] –gMIS吉密斯更新Workflow工作流、FileMgr文件柜及GTAjax等模块

这些实践,为我们最终打开 gMIS 好好与这个世界的大门,既然 ActOption 可以一种配置文件的形式嵌入到 act/view 中,那距离出现在 list 主页面的 弹出式菜单中也只有一步之遥。如果实现了某种针对 Row级别的操作,既能出现在 act/view 的窗口,也能够出现在 list主页面的弹出式菜单中,与 常规的 add\modify\view\print等相并列,则gMIS/吉密斯就具有了好好与这个世界对话的强大话语表达能力。

于是沿着这个思路,近期我们突破了自我局限,将 ActOption 的配置通过 ido, jdo, comm/ido.js 等修改实现了自动添加到 list 主页面的 弹出式菜单,与常规操作 view/modify/print 等并列。其实现方式亦颇为曲折,大致流程可以描述为:

基于 table 的xml配置信息,配置某个 <table> 的 <actoption>,
–> gMIS 解析引擎读取 <actoption>配置,
–> act=list 时, ido 负责将 actoption 输出到 JavaScript 
–> 当 comm/ido.js: showActList 被激活时,读取 JavaScript 中的 actoption ,拼入 showActList,呈现给用户. 
–> act=view 时, act/view 负责将 actoption 读取并输出.

这既像是 gMIS/吉密斯 自身打开任督二脉,实现圆通;也像是其突破了狭隘的“通用”桎梏,如虎添翼,实现了升级,将“通用”二字的外延进一步扩大。

在此之前,我们说“通用”是可以满足通常情况下的字段级的任意方式方法的输出与输入,已经有的,随配随用,需要创新的没有的输入输出方式,我们可以创制后无缝嵌入。
今天起,我们说“通用”不但可以满足字段级的任意方式方法的输入与输出,而且也可以满足任意方式方法的记录级的操作,已经有的,随配随用,需要创新的没有的操作方式方法,我们可以创制后无缝嵌入。

所谓“通用”,不是寻求某种包治百病的神药,而是普通常见的已经就绪,随去随用;而没有的,也能够见机行事,按需定制,增强适配。如此以来,“通用”则更有底气,无论是理论基础,还是实践经验,我们都信心十足,满怀干劲;既讲求事物的普遍性,也照顾到事物的特殊性;既有由个例到共性的总结归纳,也有由抽象到具象的推导演绎(Fig.2)。也许,“通用”的意思在这里,就像有“科学的科学”——哲学一样。


Fig.2 特殊到普遍,具象到抽象

自2011年创制以来,这将是 gMIS/吉密斯 发展史上的一个标志性的更新,Latest commit e8aaaf0 . 近十年来,gMIS/吉密斯 不断茁壮成长,目前已经具有如下一些鲜明的特色功能点。

创新性的数据表字段级可配置输出输入接口;
先进的无Session用户鉴权体系
创新性强大的站内搜索功能
媲美前端的点选搜索功能
模拟Office Excel的数据透视表功能
商用级别工作流支持;
层级目录式的文件管理系统;
自动跟踪记账系统;
多层级缓存局部更新等优化高速秒开页面
….
创新的数据表记录级的可配置输入输出接口;
….


-gMIS (general Management Information System) 是一种基于 -GWA2 (General Web Application Architecture) 的通用管理信息系统应用软件,具有可配置的输入和输出接口、开箱即用等特征。
可以在其上构建各种信息管理应用软件系统,如
内容管理系统(CMS), 客户资源管理(CRM), 企业资源计划管理(ERP),
办公自动化系统(OA)等, 以及各种行业应用管理系统软件,如
人力资源管理系统(HR),学生管理,档案管理,旅游管理,图书管理,
商品管理及业务运营支撑系统(BOSS)等等。
实现零代码开发、快速搭建各种管理信息系统(MIS, Management Information System).

-gMIS is a -GWA2 based Management Information System (MIS) software with characteristics like configurable input and output interfaces, open-box-to-use.
Various management application software systems can be built on it, such as
Content Management System (CMS), Customer Resource Management (CRM), Enterprise Resource Planning Management (ERP),
Office automation systems (OA), as well as different industry application management system softwares, such as
Human Resource Management System (HR), Student Management, Archive Management, Tourism Management, Book Management,
Commodity management and business operations support systems (BOSS), etc.
With zero code development, -gMIS can build a set of management information systems (MIS) software in a few minutes.

Lower Costs, 
Better Productivity.
降低成本,
提高效率.

 

This entry was posted in -gMIS, 编程技术, 计算机技术 and tagged , , , , , , . Bookmark the permalink.

发表评论

电子邮件地址不会被公开。 必填项已用*标注