图文并茂strapi 4.5.5自定义搭建指南以及数据库字段名接口返回mapping分析
strapi是什么?
基于Nodejs的开源免费CMS框架
为什么选择它?
- 基于nodejs,100%JavaScript,上手迅速
- 可轻松创建功能强大且可自定义的API
- 可以使用任何喜欢的数据库
先决条件
首先你的电脑需要具备以下环境,再执行命令
- nodejs 16+
- python3
- yarn
快速搭建Strapi项目
我选择是自定义搭建方式,创建之前,我在本地创建了一个新的数据库
执行指令
npx create-strapi-app@latest my-project
运行项目
yarn develop
开始配置
创建管理员账户设置账号密码并记住账号密码
进入strapi框架的主面板
管理后台的界面是用React写的我们可以在node_modules@strapi\admin\目录下找到相关页面文件
项目启动以后,我们打开数据库,会发现项目自动为我们创建了很多表
这个就是我刚刚创建的管理员账号
SELECT * FROM `admin_users`
我们回到管理后台
菜单介绍
下面我们来分析一下这些菜单的作用
- content-types builder是核心的内容管理器,可以建表,添加各种类型的字段。
- collection type-数据库建的表集合
- single type-相当于对象,只存一条记录
点击 Users 可以看到我们刚刚创建的账号信息
数据库字段名定义问题
接下来说一下建表以及字段名设置的问题
我们观察发现,strapi自动创建的表名都是以下划线格式命名,我们使用界面化工具来进行创建测试
我在前端界面创建
- 表名:termsInfo
- 字段名:contentInfo
保存创建内容
我们去数据库看一下我们现在创建的信息
我们可以得出结论
- 红圈部分是strapi自动帮我们创建的字段,如果我们要创建字段,不可以和已有字段名相冲突
- 红圈部分是strapi自动帮我们创建的字段,如果我们要创建字段,不可以和已有字段名相冲突
- 2.表名会自动添加s后缀,在数据库中用下划线格式命名
- 3.关于字段名,不管我们使用哪种命名格式,strapi会自动帮我们转化为下划线格式存入数据库表
我们使用不同格式的命名规则来进行测试,下面我用三种命名创建字段
我们去数据库看一下
SELECT * FROM `terms_infos`
代码分析
为什么会是这种情况呢?我们从代码可以分析得出结果
创建字段完成以后,系统调用了接口
Request URL: http://localhost:1337/content-type-builder/content-types/api::terms-info.terms-info
Request Method: PUT
我们去观察代码发现,系统自动创建了如下文件
在数据库代码中我们可以看到:
代码路径:my-project\node_modules@strapi\database\lib\index.js
我们发现,在这里,strapi帮我们存储数据的时候,把我们的命名改为了下划线格式破案啦
由此可见,不管我们使用哪种命名格式,strapi会自动帮我们转化为下划线格式存入数据库表
接口测试
我们存储几条数据,然后配置接口进行访问测试
接下来我们进行接口测试
我们先创建一条数据
然后我们配置接口权限
保存,然后访问我们配置的接口
API: http://localhost:1337/api/terms-infos
我们可以看到结果如下:
我们做个对比图
我们可以得出结论,strapi帮我们把字段名做了mapping,我们创建的就是接口返回的字段名~
字段名映射表
好啦,今天就到这里啦~~
欢迎大家指出文章需要改正之处~
学无止境,合作共赢
欢迎路过的小哥哥小姐姐们提出更好的意见哇~~
(▽)开开心心又一天~~
图文并茂strapi 4.5.5自定义搭建指南以及数据库字段名接口返回mapping分析的更多相关文章
- mybatis generator为实体类生成自定义注释(读取数据库字段的注释添加到实体类,不修改源码)
我们都知道mybatis generator自动生成的注释没什么实际作用,而且还增加了代码量.如果能将注释从数据库中捞取到,不仅能很大程度上增加代码的可读性,而且减少了后期手动加注释的工作量. 1.首 ...
- 自定义搭建PHP开发环境
学习了一段时间php了,因为之前是刚接触php,所以用的是集成安装包(wamp).现在想进一步了解apache.mysql.php之间的关系以及提升自己所以进行自定义搭建PHP开发环境.废话不多说,请 ...
- [转]OpenShift 集群搭建指南
转自:http://www.cnblogs.com/zhangning/p/7251810.html OpenShift 集群搭建指南 v1.0 搭建Hyper-v虚拟机或物理机 配置物理机静态IP, ...
- NTP搭建指南
NTP搭建指南 前言: NTP是网络时间协议(Network Time Protocol),用于全球的标准时间(UTC)的校正. 一般NTP 服务有不同的层次:一层是源头NTP 服务器,一层服务器都设 ...
- Lsyncd实时同步搭建指南
linux文件实时同步: inotify+rsync.sersync.lsyncd工具比较 一.inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify ...
- Windows下C,C++开发环境搭建指南
Windows下C,C++开发环境搭建指南 前情提要 基于近一段时间很多网友发邮件反馈,说一些项目编译出现问题,诸如此类的情况. 就觉得很有必要写一篇C,C++开发环境的小指南,统一回复. 1.君欲善 ...
- WPF管理系统开发框架搭建指南,2020从入门到放弃
WPF技术是一个很不错的技术,但一直没有上手过正式的项目,趁在做这个医疗项目时,遂搭建一个WPF开发框架,目的是为了统一WPF开发并提高开发效率:我对WPF技术算是零基础,现学现卖,用这些不成体系的文 ...
- Ubuntu16.04+Tensorflow+CUDA9.0+cuDNN7.0 环境简明搭建指南
最近在研究风格化得内容,发现搭建环境实在是很头疼的事情,虽然网上已经有各路大神总结整理好了很多搭建指南,各种问题的解决方案都已经罗列出来供大家参考.然后参考终究是参考,真正自己上手,发现仍旧是各种坑, ...
- ubuntu基于VSCode的C++编程语言的构建调试环境搭建指南
ubuntu基于VSCode的C++编程语言的构建调试环境搭建指南 首先安装g++ sudo apt install g++ 检查是否安装成功: 在插件栏安装插件c/c++.code runner: ...
- 配合crond服务实现自定义周期备份MySQL数据库(使用innobackupex进行备份)
备份 新建一个脚本/root/backup.py,内容如下: #!/usr/bin/env python# -*- coding: utf-8 -*- ''' 脚本作者:昨夜星辰 脚本作用:配合cro ...
随机推荐
- 制作一个windows垃圾清理小程序
制作一个windows垃圾清理小程序: 把下列代码保存为.bat文件(如垃圾清理.bat) 双击它就能很快地清理垃圾文件,大约一分钟不到. 就是下面的文字(这行不用复制)=============== ...
- 【vue2】Style和Class,条件,列表渲染,双向数据绑定,事件处理
目录 1.style和class 2. 条件渲染 2.1 指令 2.2 案例 3. 列表渲染 3.1 v-for:放在标签上,可以循环显示多个此标签 3.2 v-for 循环数组,循环字符串,数字,对 ...
- .NET周报【10月第3期 2022-10-25】
国内文章 聊一聊被 .NET程序员 遗忘的 COM 组件 https://www.cnblogs.com/huangxincheng/p/16799234.html 将Windows编程中经典的COM ...
- Linux--网络基础(概念+协议的了解+OSI七层模型,TCP/IP五层协议,网络数据传输流程)
网络的发展 网络的发展有下面几个阶段: 独立模式:计算机最开始是以单机模式被广泛使用的.每一台计算机都是独立的,之间不能够进行数据共享与通信 网络互联: 计算机之间可以链接在一起,完成数据共享,计算机 ...
- 通过jmeter,造50个单位的并发用户数据(用户从上至下每50个单位依次排序)
单位数据:loginfoll.csv #50个单位的信息(agencyCode,passwd,agencyname,rgcode) 用户数据:50个单位,每个单位200个用户(用户名为 ...
- 【题解】CF919D Substring
题面传送门 解决思路: DP 与拓扑结合.\(f_{i,j}\) 表示到 \(i\) 位置 \(j\) 的最大次数. 将 \(a \sim z\) 转成数字 \(0\sim 25\) ,方便存储. 考 ...
- 嵌入式-C语言基础:指针数组(和数组指针区分开来)
指针数组:一个数组,若其元素均为指针类型的数据,称为指针数组,指针数组存放的是指针类型的数据,也就是指针数组的每个元素都存放一个地址.下面定义一个指针数组: int * p[4];//[]的优先级是比 ...
- 微信小程序的学习(二)
一.数据绑定 1.数据绑定的基本原则 在 data 中定义数据 在 wxml 中使用数据 2.如何在 data 里面定义数据? 在页面对应的 .js 文件中,把数据定义到 data 对象中即可: 3. ...
- React实用插件收集
1.react-img-editor 图片编辑 demo: npm install react-img-editor -S 引入和使用 import ReactImgEditor from 'reac ...
- Tauri+Rust+Vue 跨平台桌面应用简明教程(1)环境创建+系统事件+自定义菜单
作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.JAVA底层.面试相关资料等更多精彩文章在公众号「小牛呼噜噜 」 Tauri简介 Tauri 是一个工具包,可以帮 ...