如何用smardaten无代码平台进行复杂逻辑编排?

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 如何用smardaten无代码平台进行复杂逻辑编排?

71f0f27ba9c7b83776223c629f2d9f58_75cb5338071647108ce6bd588190ace7.png

1、前言

Hello,各位小伙伴们,最近洲洲发现了一个十分好用的无代码软件平台smardaten,这是一个数据驱动的企业级无代码软件平台。

🚀 不知道各位小伙伴有没有使用过无代码软件平台的经历呢?有没有想过你可以通过简单的拖拽就能构建和部署强大的应用程序?

简单地说,smardaten无代码系统使任何人都能够开发软件,无需高深的开发知识。并且,smardaten系统拥有强大的逻辑编排业务能力,即使是最复杂的工作流程,都能够通过直观的图形界面轻松设计和管理。

ec9c1daba33336932f50ec2653c5c17d_985f5feecfa54df69ca6eb019921935d.png

2、复杂逻辑编排是什么?

可能有小伙伴会问,复杂逻辑编排具体是指什么呢?这里做一个详细的解释如下~

🧩在我们的无代码环境中,它意味着无论你的业务流程多么复杂、多么独特,都可以通过简单并且非常直观的界面,把各个模块拼凑起来,构建出完全符合你需求的应用程序。smardaten提供了丰富的工具和元素,使得无需编程知识,就能够设计出从简单的表单提交到复杂的条件决策、数据处理、通知发送等一系列功能。

🔍 这个强大的功能,对于无论是初创公司还是大型企业,都极具价值。它可以帮助你快速地构建和迭代你的应用程序,无需聘请大量的开发人员或者长时间的开发周期。可以把更多的精力和资源,投入到你的核心业务和创新上,而非技术开发上。

🚀看看未来,复杂逻辑编排的应用前景无比广阔。随着人工智能、大数据、云计算等技术的发展,未来的业务流程会变得更加复杂、更加智能。在这个趋势下,smardaten无代码系统不仅能帮助应对当前的业务需求,还能够使我们更好地适应未来的变化,抓住每一个商机。

接下来洲洲就为大家实战操作讲解使用smardaten进行复杂的逻辑编排案例:服务编排--进销存。

3、服务编排-进销存

(1)业务说明

首先我们以进销存为案例来进行服务编排。

下图是服务编排中的“商品列表页”界面详情,这个页面陈列了我们系统的商品,并显示了商品售价与库存,与此同时我们可以选择商品,对商品进行编辑、删除、查看详情等各类操作。

e8ebf7e7f1a7ba2276688a222462e7c4_23e2dc1407474b59acf421d2160707a3.png

商品详情页面,我们可以选购商品,获取售价和库存,推荐商品为选购商品相关产品,获取售价和库存。

用户具体操作如下:通过商品列表页查看可售(库存>0)商品后,选择商品,进入商品详情页后选择该商品,可选择推荐商品,进行统一购买后,后台校验库存,库存>0即可支持购买,否则提示库存不足,保存后调用第三方支付接口完成购买

75adad642ff80baa52a93d6d1b185a64_37354d80f1d645a9a9823f81d0dd12fa.png

(2)设计说明

那么上述服务编排的设计思路具体是怎么样的呢?可以看看如下所示~

简单的来说,就是管理主商品、子商品(推荐商品)的售价、库存的数据表,主/子商品表需要关联。

用户选择商品后从前端页面到服务端交互如下图。

85e0cb3d66cd319990b3a2161cc65604_23c79c6659574d72a606864ce033e8c4.png

结合上面的交互流程图,我们需要进行:

  • 数据库设计:设计主子商品表
  • 平台功能映射:整体操作是通过smardaten平台配置出来的,需要分解如何配置
    • 表单设计:选择商品的详情
    • 列表设计:展示商品的列表
    • 逻辑设计:选择商品到完成商品选择,库存扣减的逻辑.

通过用户操作链将会进行系统的操作映射,这也正是逻辑控制(服务编排)的过程,当用户提交订单之后,会出发系统的逻辑控制,逻辑控制通过服务编排配置好生成订单逻辑,服务编排处理生成订单的结果奖通过逻辑控制进行通知和提示。如下图所示,详细展示了映射过程,体现了服务编排能力。
881720d3adf0c9da52f045feb85bd067_58c9859fb7494918ae5db73cf5434bbb.png

梳理完上述的业务说明和整体设计思路之后,接下来我们详细看看如何具体的进行数据库设计、表单设计、列表设计、逻辑控制设计、服务编排设计吧~

1)数据库设计

首先是主商品表(t_a_commodity):用于表单主表中商品信息的资产选择。
d5119f8e43731681662d494613489eac_0513cedd4344454fb8a31efad50a90d5.png

其次是子商品表(t_a1_commodity):用于表单中子表中商品信息的资产选择。
d4ddaf1667a77ca43e2e2391129fd457_1daa52083b5d40afb859102e63d86c16.png

最后是订单表(t_order_form):用于选择商品后,生成订单记录。
c88ecc9b3aa28b43b04a633fdd6a2fda_4b8fe268ced24d84bbe2ea40605639b7.png

设计完物理表后,通过smardaten的数据源和数据图书馆进行连接,建立数据资产。
54c895e9d3280597bd9a4fe3205d6b7d_f9c9e22d068a4785b057da99671272e0.png

eeb69f259c57314c582b228e908ee0f6_2db99214599e4a71a6393edbec63e055.png

下图为数据资产管理。
528ffdd67a21626f7d7c9805a1fbabb6_825345c4d3984af8baba74916f0463b1.png

403a9452e65758621c0c3065a863e9be_5fe3d683953142f6a64ab33de7957670.png

2)表单设计

接下来进行表单的资产设计管理,具体操作如下。首先选中页面设置导航栏中的“表单”控件。

4a48509a237e333c1c718b9eff8dad84_6f665a065d5642c9bdf293c4a3dae72d.png

然后进入到“选择商品”表单详细界面。
1fed231764a3bcde618cb0625ed97b17_2f0c19a6e27a454cb5cb71665b19123e.png

a92a7db153e97664d2e7d41db47a281d_4129434882404fa7bfaa73f9ee535d6b.png

接着进行数据绑定,绑定主商品和子商品两张表。
9bef172d5e5e559b476d3731fae7cac5_2bb0bbcc6340466eb109c69044655f9f.png

3)列表设计

接下来进行列表设计,具体操作如下。首先选中页面设置导航栏中的“列表”控件。
675048d8636537043d99f34c8956cf32_bec1170324254a23bbca5a1cfc2a6f8f.png

选择相同表单组件,用于列表共用。
2c206d4a49e6288c02119c391727eec9_f32e3feeddd04c33b6f659c25ec47b2c.png

8967bb1dc74a66785aca5b6514fe7592_1fa90b623e2641068851778c5a118730.png

继续配置按钮。
b9adcfa156b5997408550a389f070e9b_2b7f7614fb9d43c8888b6c4594d7544f.png

7815a2ab54318cd39e5d46d154fa2caf_8fc790d7b3c348fa86b4b33dda497d27.png

这样就可以显示主表商品名称、商品售价、商品库存了~

4)逻辑设计

接下来梳理逻辑设计思路,主要根据前后端逻辑处理流程,映射至平台的逻辑控制和服务编排的配置思路。

6683a35d22d233d01fa01f0f1e248fcc_9ad6a3d06c5a40f5864f43b1bf22b68a.png

4.1 逻辑控制设计

55bec26af4fbf6973217338b45381e54_d2f75b45c4934ed7940ad458cdcc1f3a.png

  1. 组件动作:用于获取主表中组件的值
  • 选择组件:商品名称,选择动作:取值,返回值:commodity_name,值33
  • 选择组件:商品售价,选择动作:取值,返回值:commodity_price,值
    ce53d9e40703dfbbe4cadc339219494c_91ff147a9fa44b249912bff1db2392ec.png
  1. 表单取值:用于获取子表中对象数组
    变量名称:zibiao
    选择表单:子表
    选择组件:推荐商品
    变量类型:对象数组
    选取组件:推荐商品、推荐售价、剩余库存
  2. 服务编排
    b3b5e9d99ccd772265a0e825053a7cd7_370fcbcddedc49caa3adcc21eac2d346.png
  • 参数列表
    commodity_price=commodity_price
    zibiao=zibiao
    commodity_name=commodity_name
  • 返回结果
    msg=message
  1. 条件分支
    b7f1b505078a983d65d1a03c9c29a565_8ea1f688c0a64ff0a587dbdcddcbfde1.png
  1. 通知提示
    da94e8d3b2e11ec2ae5b06908e00a717_9813937af81d4858b54a4bc3455cbd7b.png

提示类型:成功提示,内容类型:变量,变量选择msg即可。
4dc5f78f43450e5e81f660fe89f6a276_c8e09673f8d74a279be8e28850b376ca.png

提示类型:失败提示,内容类型:变量,变量选择msg。

4.2 服务编排设计

在服务编排设计中,一共共17个节点。

  1. 开始节点
    81b4d67638b0836435e9a87d5bd388ea_6bc612cfa095419cb148dd3d8f4a3af3.png

bacd069dda9a63127691c78ca4823074_579c337e8c074ee2bfd2c972bb229333.png

  1. S3数据读取:
    db49159abb1b582c2acd17b7da2ac1db_491c3800d0414df0bcb5ffcd067ce1c9.png
  • 简单模式
  • 选择资产:主商品表
  • 筛选条件:commodity_name等于commodity_name
  • 输出字段:commodity_id=文本,commodity_stock=数值
  • 输出变量:cList=对象数组
  1. S5变量计算
    a114485df1f71be4c5042901c388724b_6df9ba6ddf204042bc59e3e6cbc31571.png

ea6ac1df98cde302325fee6fe0e9fc30_834ff313bfab41b3b3ab449cb92a7144.png

  1. S4分支判定
    6d0d547cd12169a022144119858b4d22_46ef2eac49fb4ab79c160c1909a8ba8d.png

表达式:cList[0].commodity_stock>0

  1. S16变量计算(分支判定否)
    8a8bf88b9b2f799bc6d4beb7c81cefba_383ae3e4ebf14ddd969cb992cf4f0a1c.png

0d9b8e5a27084aefbb8763a103cb2318_d3af61a21a3f48068c019aefe0d4a22e.png

  1. S6循环判定(分支判定是)
    5a7bf3a079372ed4835c53a40d4bf552_4b16d2b72ee043d29b8a9ddce629fe5d.png

模式:遍历,选择变量:zibiao,循环游标:i,循环变量名:a,循环变量类型:字符串

  1. S7变量计算(循环判定是)
    31b72560041f1d57c0eb39d9cde924d5_7320552e8a5048ad94cb0a9da3082e6d.png

3d4e9ee734ff858c37fa8be1c7171a35_68f9c197f620401b8ef630450cc2306d.png

  1. S8数据读取
    2c9ec2cff48b41abcee64c755e750a3a_de3010212e8f4c868641246f12a6d571.png
  • 操作模式:简单模式
  • 选择资产:关联商品表
  • 筛选条件:commodity_name等于z_commodity_name
  • 输出字段:
    commodity_name=文本
    commodity_id=文本
    commodity_price=数值
    commodity_stock=数值
    commodity_state=日期时间
    t_rel_commodity_id=文本
  • 输出变量:z_commodity_stock=对象数组
  1. S9分支判定
    b4a98fd867351bfea52abd6d0dff6ee6_56cacf17743047b1ab1892bca09c4766.png

表达式:zList[0].commodity_stock>0

  1. S12变量计算
    67a497dfa92a821c212135319381c7b9_95b494333de546949682c5ab5a582398.png
  1. S19数据操作
    b165733a1239c56a80e02bfea61b8fb8_2588d3c1b6fc4aee93e3d3615eded1fa.png

选择高级模式(向订单表中插入商品信息):insert into t_order_form(order_state,order_date,commodity_id,commodity_name,commodity_price) values ('1',now(),'${commodity_id}','${commodity_name}','${commodity_price}')

  1. S20数据操作
    b3e47df8533a374690eb1cdd90b059b2_187b52498f774cb1a1421e9d315052a5.png

选择高级模式(对商品表中库存字段做减1操作)
update t_a_commodity set commodity_stock=commodity_stock-1 where commodity_id="${commodity_id}" and commodity_stock>0

  1. S13循环判定
    f3d0c79ece693e9b9ab10c77b4179e08_53e80a20acb74c5a9c11dca88bd99f0d.png
  1. S22Restful调用(S13循环判定否)
    18d11f1d101446d51dc7c7fb138a27d4_e3a8ca6bbcf14ffb9e8ecb572e5e0166.png

接口地址(GET):
https://www.fastmock.site/mock/f4f85dbdda50d38747d0545c6e5eea41/shop/shop/shop_01

  1. S14变量计算
    8265f2042e23ab040f66dcffad43c4a8_241d3f392d744984bee4e5ced0b360f0.png
  1. S21变量计算(S13循环判定是)
    0e5b336d7260a9cd379a7bf477afe941_52ddd12b633b4a5e8b9cf3d43e5ebf3e.png
  1. S10数据操作
    9924486fcb06569b99b40eda6749d050_c38bc6956de24ffcb3289eef35648c53.png

insert into t_order_form(order_state,order_date,commodity_id,commodity_name,commodity_price) values ('1',now(),'${z_commodity_id}','${z_name}','${z_commodity_price}')

  1. S18数据操作
    3843f4aaa06753f8479f15eab46320ed_7e2b30513b3f48cf83f364d12e1ecea4.png

update t_a1_commodity set commodity_stock=commodity_stock-1 where commodity_id="${z_commodity_id}" and commodity_stock>0

4、使用体会与感想

怎么样,看到这里,你是否心动了呢!

在使用smardaten无代码平台开发商品进销存功能的过程中,我对它的复杂逻辑编排功能留下了深刻的印象。这一强大的功能让我能够十分直观地组织整理与编排复杂的业务流程,这无疑大大简化了系统的业务应用开发复杂度。

通过直观的操作界面与清晰明了的设计流程,我能够非常精细地控制各个业务模块,例如进行列表设计、变量处理、数据处理等等,从而让整个系统更加全面地符合系统的业务需求。

不仅如此,我认为服务编排功能也给我带来了很大的便利。它使我能够以模块化的方式管理各种服务,减轻了在处理复杂业务逻辑时的压力。

我特别欣赏这种将复杂问题分解为更小、更易于管理的部分的方法,这无疑增强了我的开发效率。

我对smardaten的复杂逻辑编排和服务编排功能非常满意,并且smardaten这类业务功能方面的上手教学方面也做的非常好。例如,提供非常多的现有模板和实例,以此支持大家进行二次开发的需求,我相信这将对初学者和非技术背景的用户非常有帮助。

此外,smardaten增强了复杂逻辑编排的自动化程度并极大程度地简化了设计思路,这将有助于进一步提高开发效率。

其实要我说,不仅仅是上面提到的复杂逻辑编排能力,我的总体体验过程流畅如行云流水,smardaten无代码平台带给我最深刻的感触就是它强大而直观的操作界面。相比其他市面上花哨且复杂的产品,smardaten的设计理念更注重实用性和易用性。他们还有六大优势。
598f3f2f8892c3bd5ce16cc830924a82_630b9a01ca694aa7ac8b6c60c15fec36.png

这个平台配备了完整的开发模板、详尽的使用文档和生动的教学视频,让所有级别的使用者,无论新手或经验者,都能快速上手。更棒的是,它支持多人协同操作,这种协作模式大大提高了开发和交付的效率。

ac4058a9a5fe4d531aa2708210767a37_32e0130434f1491dbaaef77a2401e8be.png

那些传统编程方式可能需要数天才能完成的工作,在smardaten平台上,通过简单的拖拉拽操作,半小时就能完成。我热情地推荐那些寻求更高效方式,而又不希望自行编程的朋友们亲自体验smardaten的魅力。你只需花费20分钟,就可以在他们的S3社区https://s3.smardaten.com/ 完成快速配置,让你有更多的精力和时间专注于业务逻辑的实现。

smardaten的能力远不止于此,它不仅能创建动态的大屏应用,更是实现了“数据驱动、企业级、无代码”这三大主打方向。不论是在数据处理、分析、管理还是运营领域,smardaten都能提供一站式的无代码开发环境,从而加速企业级复杂应用的开发。全过程的数据接入、治理与管控功能,构建了一个坚实的数字化应用支撑基座。让我们一起看看smardaten的架构图。怎么样!超酷的有没有!

c8bcc41765e929cec5e30a1cb1229ad6_5dded2eacc384fa38dd2ddc31b1c75e8.png

此外,smardaten还配备了强大的智能分析工具,为2/3D可视化应用场景提供了无代码化构建的能力。

所有这些充满魅力的功能,都在这里等待着我们去探索和解锁...

相关文章
|
6月前
|
数据库
易搭工作流引擎用是什么开源 还是阿里自研产品,零代码平台场景页面映射数据库表是动态创建,采用什么框架处理,怎么让系统产生高并发能力。易搭权限有没有了解,求解。
易搭工作流引擎用是什么开源 还是阿里自研产品,零代码平台场景页面映射数据库表是动态创建,采用什么框架处理,怎么让系统产生高并发能力。易搭权限有没有了解,求解。
|
7月前
|
敏捷开发 测试技术
推三返一开发稳定版丨推三返一项目系统开发详细指南/方案需求/步骤逻辑/流程功能/案例设计/技术架构/源码程序
推三返一系统开发是一种软件开发模式,也被称为迭代增量开发模式。它是一种敏捷开发方法的一种,通过将整个开发过程分为多个迭代周期,每个周期都会增加新的功能和特性,并在每个迭代周期结束后进行测试、反馈和修改。推三返一系统开发的核心思想是“推进三步,反馈一步”。
|
7月前
|
JSON 数据可视化 JavaScript
OneCode 基于“真实代码”代码的建模设计,无缝整合二次开发
在很多优秀的低代码平台中都支持了本地代码导出的设计,方便开发者二次集成,但能够导出的前提是已经通过低代码平台进行了初步的数据建模,界面绘制等基础性的操作。这些导出的代码虽然很大程度上减轻了开发者的代码量,但在项目的迭代过程中,遇到数据或需求变更。这些代码就又会成为开发者巨大的负担,重新由低代码平台建模会产生代码上的冲突无法解决,而重新用code编写这一步代码则又面临手工代码与“机器代码”的整合问题。而更为致命的问题是项目上线后,当直接用户希望通过低代码工具进行维护系统时更是“闪崩”。 本文将结合OneCode的底层编译原理来讲解 OneCode基于真实代码的建模解决方案。
|
7月前
LiteFlow学习三之业务编排处理之外
LiteFlow学习三之业务编排处理之外
141 0
|
10月前
|
数据可视化 前端开发 JavaScript
可视化逻辑编排工具——低代码/无代码
可视化逻辑编排工具——低代码/无代码
337 0
|
12月前
|
存储 自然语言处理 算法
GaiaX开源解读 | 表达式作为逻辑动态化的基础,我们是如何设计的
GaiaX跨端模板引擎,是在阿里优酷、淘票票、大麦内广泛使用的Native动态化方案,其核心优势是性能、稳定和易用。本系列文章《GaiaX开源解读》,带大家看看过去三年GaiaX的发展过程。
243 0
|
人工智能 大数据 程序员
一文看懂开源图化框架中的循环设计逻辑!
相信大家在日常工作中,已经精通各种循环逻辑的实现。就拿我来说吧,多年的工作经验,已经让我可以熟练的使用 C++,Python,英语等多种语言,循环多次输出“hello word”。不过大家有没有想过一个这样的问题:如何在一个有向无环图(Directed Acyclic Graph,简称dag)中实现循环呢?
568 0
一文看懂开源图化框架中的循环设计逻辑!
|
存储 自然语言处理 算法
作为逻辑动态化的基础,GaiaX 表达式是如何设计的? | GaiaX 开源解读
GaiaX 跨端模板引擎,是在阿里文娱内广泛使用的 Native 动态化方案,其核心优势是性能、稳定和易用。本系列文章《GaiaX 开源解读》,带大家看看过去三年 GaiaX 的发展过程。 GaiaX 开源地址:https://github.com/alibaba/GaiaX
331 0
作为逻辑动态化的基础,GaiaX 表达式是如何设计的? | GaiaX 开源解读
|
传感器 存储 SQL
应用编排与管理:核心原理|学习笔记
快速学习应用编排与管理:核心原理
86 0
应用编排与管理:核心原理|学习笔记
|
数据可视化 前端开发 Java
云巧组件如何实现代码架构设计可视化
在项目搭建完成进行了N个迭代之后,往往因为需求的变化以及设计的缺陷导致领域模型、接口、数据库设计等和最开始的时候大为不同,架构设计需要保鲜会花去大量的时间。有没有一种办法可以实时反应项目的各种技术设计呢?就像Swagger一样,代码自动生成文档。我们采用了静态代码扫描的方案,通过代码来反应真实的技术设计,这就是《云巧工坊-应用素描》的功能。
234 0