微搭低代码入门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

相关文章

使用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实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c