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

2024-05-06 08:28

本文主要是介绍微搭低代码入门04数据模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1 创建数据模型
  • 2 一对多
  • 3 通用选项集
  • 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,只有基本功打扎实才能够写出自己想要的功能来。

这篇关于微搭低代码入门04数据模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/963882

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引