微搭低代码入门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 Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js