微搭低代码入门04数据模型

目录

  • [1 创建数据模型](#1 创建数据模型)
  • [2 一对多](#2 一对多)
  • [3 通用选项集](#3 通用选项集)
  • [4 API](#4 API)
  • 总结

上一篇我们介绍了页面管理,页面是盛放组件的容器,组件在配置属性的时候需要进行数据绑定。数据是通过创建数据模型来进行存储,本篇我们介绍一下数据模型的相关操作。

1 创建数据模型

微搭底层的数据库叫flexdb,是一个文档型数据库。传统关系型数据库的表对应于微搭底层的集合,传统的记录对应于文档。和传统数据库不同的是,微搭的字段比较丰富,可以方便的存储各类数据。

打开控制台,找到数据模型,点击+号进行新建

输入数据源的名称,会自动生成标识

这里的标识一般用在我们的数据源相关的API中

数据模型创建之后,点击编辑,就可以添加字段

点击添加字段,就可以设置各类字段,字段类型常见的有文本、数字、数组、关联关系、图片、文件等

2 一对多

一般设计数据源的时候,可以参考传统的理论,比如数据库的范式理论

第一范式(1NF):在关系模型中,所有的域都应该是原子性的,即数据库表的每一列都是不可分割的原子数据项,而不能是集合、数组、记录等非原子数据项。简单来说,第一范式要求表中的数据项是原子的、不可再分的。

我们微搭中提供了数组、对象的字段类型,主要是为了方便开发小程序

第二范式(2NF):在1NF的基础上,非码属性必须完全依赖于候选码(消除非主属性对主码的部分函数依赖)。第二范式要求数据库表中的每个实例或记录必须可以被唯一地区分。

这里微搭为每个数据源都创建了数据标识(_id)确保记录的唯一性

第三范式(3NF):在2NF的基础上,任何非主属性不依赖于其他非主属性(消除传递依赖)。第三范式进一步限制了数据冗余,确保数据表中的每一列都直接与主键相关,而不是通过其他非主键列间接相关

在遵循范式的基础上,为了消除冗余,我们通常是做表拆分。表拆分就需要确定主表和子表的关系。那什么作为主表呢?通常考虑如果在数据录入的时候,需要做下拉选择,而且需要运营人员日后维护数据的,我们考虑将这类数据拆分为主表。

比如产品和产品分类关系,在录入产品的时候通常需要选择分类,这样将分类表拆分为主表,产品表作为子表。


这样拆分之后,我们在录入数据的时候,产品分类就可以作为下拉项进行选择,避免了直接录入数据不准确的问题

至于怎么做表拆分,这是一个经验的问题,你在实际开发尤其上线在不停地维护中就可以检验你的表设计的是否合理。

3 通用选项集

通用选项集可以理解为数据字典,通常我们的字段设置为枚举类型的,日后需要维护选项的可以考虑在通用选项集里维护

什么字段设置为枚举项,比如我们订单的状态,有卖家已付款,商家已确认,待收货,已完成这些。在用户状态分为待审核、已审核、未通过的区分,主要还是用来完成流程状态的区分。

4 API

API作为微搭的后端,提供了Http接口、自定义代码和云函数的三个选项

如果希望集成第三方能力的,可以选择Http接口,比如我现在有一个获取地图数据的接口

https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json

请求的类型可以选择GET,输入URL,然后点击方法测试就可以看到返回的结果

测试成功之后点击出参映射,我们的接口就开发完了。API开发完之后就可以在小程序里调用,我们在自定义方法里介绍如何调用API

自定义代码相当于简化版的云函数,不能安装npm包,但可以使用官方封装的各类API。云函数就比较灵活了,可以安装第三方npm包,可以按照需要编制后端代码

总结

我们本篇介绍了数据源的创建方法,介绍了通选选项集的概念,介绍了API的各种能力。当然要用好这些能力就必须熟练掌握nodejs,只有基本功打扎实才能够写出自己想要的功能来。

相关推荐
NocoBase1 天前
GitHub 上星星数量前 10 的 AI CRM 开源项目
人工智能·低代码·开源·github·无代码
流之云低代码平台1 天前
低代码开发,助力企业快速响应市场变化!
低代码·gadmin·低代码开发优势·低代码开发平台应用场景·低代码开发平台选择·低代码开发未来趋势·企业专属应用
液态不合群1 天前
探索与创新:低代码助力金融数字化转型发展
低代码·金融
Light602 天前
Vue 高阶优化术:v-bind 与 v-on 的实战妙用与思维跃迁
前端·低代码·vue3·v-bind·组件封装·v-on·ai辅助开发
液态不合群4 天前
深入浅出:落地应用之「低代码平台」制造业篇
低代码
数式Oinone4 天前
数式Oinone7早鸟体验版发布,全面适配JDK17,AI Native加速产品智能化转型
人工智能·低代码·低代码平台·数式oinone
2501_931876434 天前
开源低代码平台如何扮演企业创新基座?连接业务、数据与技术的核心枢纽
低代码·开源
gq20105 天前
用内控服务学校治理——基于数式Oinone的高校内控数智化实践
低代码·内控
流之云低代码平台5 天前
企业合同管理的安全锁——合同系统智能化
低代码·案例分析·合同系统智能化·企业合同管理·合同管理挑战·智能化优势·实现方法
无代码专家5 天前
无代码解决方案:破解企业数字化转型效率困局
低代码