MySQL表设计经验汇总篇
文章目录
- 1、命名规范
- 2、选择合适的字段类型
- 3、主键设计要合理
- 4、选择合适的字段长度
- 5、优先考虑逻辑删除,而不是物理删除
- 6、每个表都需要添加通用字段
- 7、一张表的字段不宜过多
- 8、定义字段尽可能not null
- 9、合理添加索引
- 10、通过业务字段冗余来减少表关联
- 11、避免使用MySQL保留字
- 12、尽量避免外键关联,一般都在代码维护
- 13、字段注释
- 14、时间的类型选择
- 15、SQL 编写的一些优化经验
表设计是每一个后端程序员都无法避开的一块砖,而且这块砖一不小心就很容易烫手,本篇笔记就是为了帮助大家在设计表时能够轻松拿捏。
1、命名规范
数据库表名、字段名、索引名等都需要命名规范。命名可读性要高,尽量使用英文,采用驼峰或者下划线分割的方式让人见名知意。
反例:这些命名过于简单,缺乏描述性,很难让人理解它的含义。
1.表名: a、b、c
2.字段名: aaa、bbb、ccc
3.索引名:index1、index2、index3
正例:这些命名就让人见名知意
1.表名: customers、orders、products
2.字段名: customer_ id、order_date、product name
3.索引名: idx_customer_id、idx order_date
Tips:表名、字段名必须使用
小写字母
,禁止使用数字开头,禁止使用拼音,并且一般不使用英文缩写。
主键索引名为pk_字段名; 唯一索引名为uk_字段名;普通索引名则为idx_字段名.
2、选择合适的字段类型
设计表时,需要选择合适字段类型,比如说
1)根据数据类型选择字段类型:不同的数据类型应该使用不同的字段类型。
- 整数型数据可以使用 INT 或 BIGINT 类型
- 浮点型数据可以使用 FLOAT 或 DOUBLE 类型
- 字符型数据可以使用 VARCHAR 或 CHAR 类型。
2)考虑数据长度: 字段类型应该根据所需存储的数据长度来选择。
- 如果某个字段的数据长度不会超过 10 个字符,则可以使用 CHAR(10) 类型代替 VARCHAR(50)类型,以节省空间。
- 如果存储的值太大,建议字段类型修改为text,同时抽出单独一张表,用主键与之对应
3)注意精度和小数位数:
- 对于需要精确数值计算的字段(如货币和百分比),应该选择带有精度和小数4位数的字段类型(如 DECIMAL)
4)考虑数据完整性:字段类型也应该考虑到数据完整性
- 日期型数据应该使用 DATE 或 DATETIME 类型,以确保输入的日期格式正确.
3、主键设计要合理
主键的设计在数据库中非常重要,它用于唯一标识表中的每一行数据,并且在数据操作和查询中起到关键作用。通常主键的设计,不要与业务相关联,因为业务是会发生变化的,应当使用自增的 id
,并且保持主键的连续性
。比如说可以使用优化的雪花 id 等等。
4、选择合适的字段长度
首先问大家一个问题,数据库字段长度表示字符长度还是字节长度?
在mysql中,varchar和char类型表示字符长度,而其他类型表示的长度都表示字节长度,char(10)表示字符长度是10。
bigint (4)表示显示长度是4个字节,但是因为bigint实际长度是8个字节,所以bigint(4)的实际长度就是8个字节。
所以在设计表时需要充分考虑一个字段的长度,比如一个用户名字段(它的长度5~20个字符),你觉得应该设置多长呢?可以考虑设置为 varchar (32) 。需要注意字段长度一般设置为2的n次方。
5、优先考虑逻辑删除,而不是物理删除
什么是物理删除? 什么是逻辑删除?
- 物理删除: 把数据从硬盘中删除,可释放存储空间
- 逻辑删除: 给数据添加一个字段,比如is_deleted,以标记该数据已经逻辑删除
为什么推荐用逻辑删除,不推荐物理删除呢?
- 数据恢复困难。
- 物理删除会导致索引树重构
6、每个表都需要添加通用字段
- id: 主键,一个表必须得有主键,必须
- create time:创建时间
- creator : 创建人
- update time: 修改时间,必须,更新记录时,需要更新它
- update by :修改人,非必须
- remark :数据记录备注,非必须
7、一张表的字段不宜过多
建表的时候一张表的字段不要太多了。尽量不超过 20 个。超出的话优先考虑拆分,也就是通常的查询表,详情表
- 查询效率:当表中保存的数据数量很大时,查询操作需要检索的数据也会随之增加。如果表的字段数过多,查询操作就需要读取更多的数据,这会导致查询效率变慢。
- 存储空间: 表的字段数越多,每一行数据占用的存储空间也就越大。对于大型数据库来说,这可能会导致磁盘空间的浪费
- 数据库设计复杂性:当表的字段数过多时,数据库的设计和维护变得更加复杂。这可能涉及到索引和关联表的设计,以确保数据的完整性和一致性。
8、定义字段尽可能not null
如果没有特殊的理由,一般都建议将字段定义为 NOT NULL 。为什么呢?
首先,NOT NULL 可以防止出现空指针问题。其次,NULL值存储也需要额外的空间的,它也会导致比较运算更为复杂,使优化器难以优化SQL。NULL值有可能会导致索引失效
如果将字段默认设置成一个空字符串或常量值
并没有什么不同,且都不会影响到应用逻辑,那就可以将这个字段设置为NOT NULL。
9、合理添加索引
当设计表时,需要考虑哪些字段需要加索引,可以遵循以下几个原则:
- 根据查询条件进行选择(高频使用》:如果在查询中使用了某个字段作为查询条件,那么这个字段就应该建立索引。例如,在用户表中,如果需要根据用户的姓名进行查询,那么就应该为姓名字段建立索引。
- 区分度高的字段优先:如果一个字段的取值范围非常小,例如性别只有男女两种可能,那么这个字段就不适合建立索引。相反,如果一个字段的取值范围很大目区分度高,例如用户D,那么这个字段就非常适合建立索引。
- 不要建立过多的索引: 每个表所建立的索引数量应该控制在一个合理的范围内,一般不要超过5个。因为过多的索引会导致写入速度变慢,并占用更多的存储空间。
- 联合索引优化:在某些情况下,可以通过联合索引的方式来优化查询速度
- 减少所需的索引数量。例如,在用户表中,如果需要根据用户姓名和年龄进行查询,那么可以将这两个字段组合成联合索引。
10、通过业务字段冗余来减少表关联
简单来说就是反范式设计。回顾下什么是数据库三范式 (3NF) ?
- 第一范式:对属性的原子性,要求属性具有原子性,不可再分解;
- 第二范式:对记录的唯一性,要求记录有唯一标识,即实体的唯一性,即不存在部分依赖;
- 第三方式:对字段的冗余性,要求任何字段不能由其他字段派生出来,即不存在传递依赖。
假设需要设计一个产品订单表,句含以下字段:订单D、用户D、订单日期、产品名称、产品价格、产品数量以及订单总价。正常情况下,可能会分别设计订单表和产品表,并使用外键进行关联:
CREATE TABLE order (
'id' int(11) NOT NULL AUTO_INCREMENT,
'user_id' int(11) NOT NULL,
'order_date' date NOT NULL,
'product_id' int(11) NOT NULL,
'quantity' int(11) NOT NULL,
PRIMARY KEY ('id'),
FOREIGN KEY ('product_id'), REFERENCESproduct('id')
)ENGINE=InnoDB DEFAULT CHARSET=utf8;CREATE TABLE product (
'id' int(11) NOT NULL AUTO_INCREMENT,
'name' varchar(255) NOT NULL,
'price' decimal(10,2) NOT NULL,
PRIMARY KEY ('id')
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
这个设计方式符合范式要求,但在查询时需要进行表关联操作,可能会降低查询效率。为了提高查询效率,我们可以使用反范式的设计方式,将订单表中的产品名称、产品价格和订单总价几余存储到订单表中,从而避免关联查询。例如:
CREATE TABLE order (
'id' int(11) NOT NULL AUTO_INCREMENT
'user_id' int(11) NOT NULL
'order_date' date NOT NULL,
'product_name' varchar(255) NOT NULL
'product_price' decimal(10,2) NOT NULL,
'quantity' int(11) NOT NULL,
'total_price' decimal(10,2) NOT NULL
PRIMARY KEY ('id')
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
通过这种反范式的设计方式,我们可以避免表关联操作,提高查询效率。但同时也带来了一些缺点,例如数据冗余、数据更新困难等。因此,在实际应用中需要根据具体情况进行选择。
11、避免使用MySQL保留字
如果库名、表名、字段名等属性含有保留字时,SQL语句必须用反引号来引用属性名称,这将使得SQL语句书写SHELL脚本中变量的转义等变得非常复杂。
如果你需要使用这些保留字作为表名、列名或其他标识符,你可以考虑以下方法来避免冲突:
- 1.在标识符前或后添加下划线: 例如,将表名命名为“my_table",列名命名为"column_name"
- 2.使用不同的单词或短语: 例如,将表名命名为"orders_table",列名命名为"order_status"
- 3.使用反引号 ()将标识符括起来: 例如,将表名命名为"table",列名命名为"column"。请注意,在使用反引号时要小心,确保使用正确的语法和规范
12、尽量避免外键关联,一般都在代码维护
在数据库设计中,使用外键关联是一种良好的实践,可以确保数据的完整性和一致性。外键关联可以帮助维护表之间的关系,防止无效或不一致的数据插入、更新或删除操作。然而,在某些情况下,也存在一些缺点,这可能是导致现在不太推荐使用外键关联的原因之一。以下是一些这种情况:
- 1.可能会导致性能问题,尤其是在对大型数据集进行操作时。这是因为每次插入、更新或删除操作都需要进行约束检查,这可能会导致额外的开销和延迟。
- 2.可能会限制数据库的灵活性和可扩展性。例如,如果需要对数据库进行分区或垂直分割,外键关联可能会导致额的复杂性和限制。
- 3.可能会导致死锁和死循环,特别是在进行并发操作时。这可能会导致数据库出现不稳定的状态,从而影响系统的性能和可用性。
- 4.可能会导致数据库的维护和管理成本的增加。这是因为外键关联需要额外的管理和维护工作,例如添加、修改或删除外键约束时需要额外的测试和验证。
因此,在决定是否使用外键关联时,需要考虑实际业务需求和场景,并进行权衡和决策。在某些情况下,可以采用其他方法来保证数据的完整性和一致性,例如使用应用程序逻辑或数据库触发器来实现约束检查和数据操作。同时,需要注意数据库设计的基本原则和最佳实践,例如避免数据冗余、遵循规范化原则。
13、字段注释
设计表时每个字段的含义要注释清楚,包括枚举类型。比如说:
order_status varchar(2) NOT NULL COMMENT'订单状态: 01: 待支付 02:已支付 03:已发货 04:已完成 05: 已取消';
14、时间的类型选择
时间类型的选择一般都要好好考虑,因为不同的类型存储的格式不同。
对于MySQL来说,主要有date、datetime、time、timestamp 和 year。
- date : 表示的日期值,格式yyyy-mm-dd,范围1000-01-01到 9999-12-31,3字节
- time : 表示的时间值,格式 hh:mm:ss,范围-838:59:59 到 838:59:59,3字节
- datetime: 表示的日期时间值,格式yyyy-mm-dd hh:mm:ss,范围1000-01-01 00:00:00到9999-12-3123:59:59,8字节,跟时区无关
- timestamp:表示的时间戳值,格式为yyyymmddhhmmss,范围1970-01-01 00:00:01到2038-01-19 03:14:07,4字节,跟时区有关
- year:年份值,格式为yyyy。范围1901到2155,1字节
Tips:推荐优先使用datetime
类型来保存日期和时间,因为存储范围更大,且跟时区无关
15、SQL 编写的一些优化经验
- 1.避免使用SELECT* FROM 语句,应该只选择需要的列,以减少网络传输和提高查询性能。
- 2.使用索引来提高查询速度,特别是在对大型表进行查询时
- 3.避免使用外键约束,因为它们可能会导致性能问题,特别是在对大型表进行插入、更新和删除操作时
- 4.使用LIMIT 1来限制查询结果只有一条记录
- 5.避免在where子句中使用OR来连接条件,应使用UNION来连接查询。
- 6.注意优化LIMIT深分页问题,可以使用OFFSET来替代LIMIT。
- 7.使用where条件限制要查询的数据,避免返回多余的行
- 8.尽量避免在索引列上使用MySQL的内置函数,这可能导致索引失效.
- 9.应尽量避免在where子句中对字段进行表达式操作,这可能导致索引失效
- 10.应尽量避免在where子句中使用!=或<>操作符,这可能导致索引失效。
- 11.使用联合索引时,注意索引列的顺序,一般遵循最左匹配原则。
- 12.对查询进行优化,应考虑在where及order by涉及的列上建立索引。
- 13.如果插入数据过多,考虑批量插入。
- 14.在适当的时候,使用覆盖索引。
- 15.使用EXPLAIN 分析你SQL的计划。
相关文章:
MySQL表设计经验汇总篇
文章目录 1、命名规范2、选择合适的字段类型3、主键设计要合理4、选择合适的字段长度5、优先考虑逻辑删除,而不是物理删除6、每个表都需要添加通用字段7、一张表的字段不宜过多8、定义字段尽可能not null9、合理添加索引10、通过业务字段冗余来减少表关联11、避免使…...
Servlet基础(续集2)
HttpServletResponse web服务器接收到客户端的http的请求,针对这个请求,分别创建一个代表请求的HttpServletRequest对象,代表响应的一个HttpServletResponse 如果要获取客户端请求过来的参数:找HttpServletRequest如果要给客户端…...
【云原生】创建harbor私有仓库及使用aliyun个人仓库
1.安装docker #删除已有dockersystemctl stop docker yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine #安装docker yum install -y docker-ce-20.10.1…...
什么是SOLIDWORKS科研版
随着科技的不断进步,工程设计和科学研究变得越来越复杂,需要更强大的工具来满足需求。SOLIDWORKS科研版就是在这样的背景下诞生的,它为科研人员和工程师提供了一套全方面、快捷的解决方案,以应对各种科研和工程挑战。 SOLIDWORKS科…...
微信小程序页面配置
页面配置 小程序的配置可以配置页面路径、窗口表现、tabBar等,分为全局配置和页面配置,全局配置针对所有页面生效,页面配置只针对当前页生效。 全局配置 (app.json) (1) 路径配置 pages 配置页面路径,未配置路径的页面无法被访…...
如何将JPG/PNG位图免费快速一键转换成SVG格式的矢量图
环境: JPG/PNG位图 问题描述: 如何将JPG/PNG位图快速一键转换成SVG格式的矢量图 解决方案: 是一个人工智能驱动的图片转换工具,可以帮助用户将」JPG/PNG位图快速转换成SVG格式的矢量图,方便设计人员对图片进行二次…...
YOLO检测环境安装配置
YOLO介绍 YOLO学习手册:YOLO教程 YOLO [ˈjoʊloʊ](You Only Look Once)是一种快速而准确的目标检测算法,由Joseph Redmon等人在2016年提出。YOLO被广泛应用于计算机视觉领域,包括实时视频分析、自动驾驶、安防监控、…...
NOSQL -- ES
第三个我们比较常用的NOSQL类型的数据库 --- ES 介绍: ES的全称(Elasticsearch) ES是一个分布式全文搜索的引擎 也就是我们平常在购物, 搜索东西的时候常用的, 就是一个ES的类型, 分布式全文搜索引擎 查询原理: 1>分词: 在查询之前, 其会将一些数据拆分开, 按照词进行拆分…...
【Python基础】名称空间和作用域
1.名称空间 将栈区进行分类,这些分类就是名称空间 名称空间存放什么名字空间个数何时创建&销毁内置名称空间built-inPython解释器内置的名字1个Python解释器启动&解释器关闭 全局名称空间 global Python文件内定义的类名,变量名,模块…...
安全智能预警软件有人试图窃取会立即发出高分贝警报已解锁VIP功能
一款手机安全智能预警软件,无论是网吧还是餐馆小聚,您的手机都能得到贴心的守护,一旦有人试图窃取,应用会立即发出高分贝警报,确保您在公交、地铁、商场等拥挤环境中依然能牢牢掌控手机。(解锁专业版&#…...
DeepSORT(目标跟踪算法)中自由度决定卡方分布的形状
DeepSORT(目标跟踪算法)中自由度决定卡方分布的形状 flyfish 重要的两个点 自由度决定卡方分布的形状(本文) 马氏距离的平方在多维正态分布下服从自由度为 k 的卡方分布 独立的信息 在统计学中,独立的信息是指数据…...
cordic IP核中,sin and cos的使用
参考视频:FPGA IP之CORDIC_哔哩哔哩_bilibili FPGA IP之CORDIC使用与仿真_哔哩哔哩_bilibili 一、参数说明 functional selection rotate是旋转,sin and cos是计算这两个三角函数,sinh和cosh是计算双曲正弦和双曲余弦 phase format 对于…...
SpringSecurity入门(三)
12、密码加密 12.1、不指定具体加密方式,通过DelegatingPasswordEncoder,根据前缀自动选择 PasswordEncoder passwordEncoder PasswordEncoderFactories.createDelegatingPasswordEncoder();12.2、指定具体加密方式 // Create an encoder with streng…...
luogu-P10570 [JRKSJ R8] 网球
题目传送门: [JRKSJ R8] 网球 - 洛谷https://www.luogu.com.cn/problem/P10570 解题思路 数学问题,暴力这个范围会超时。 首先,找出这两个数的最大公因数,将这两个数分别除以最大公因数,则这两个数互质,判…...
ASP.NET的WebService跨域CORS问题解决方案
ASP.NET WebService 跨域(CORS, Cross-Origin Resource Sharing)问题通常发生在当您尝试从不同的源(域名、协议或端口)调用 WebService 时。浏览器由于安全原因,默认会阻止此类跨域请求。为了解决这个问题,您需要在 WebService 服务器端配置 CORS。 以下是在 ASP.NET We…...
大众点评全国爱车店铺POI采集177万家-2024年5月底
大众点评全国爱车店铺POI采集177万家-2024年5月底 店铺POI点位示例: 店铺id H69Y6l1Ixs2jLGg2 店铺名称 HEEJOO豪爵足道(伍家店) 十分制服务评分 7.7 十分制环境评分 7.7 十分制划算评分 7.7 人均价格 134 评价数量 2982 店铺地址 桔城路2号盛景商业广场1-3…...
【文献阅读】LORA: LOW-RANK ADAPTATION OF LARGE LANGUAGE MODELS
目录 1. motivation2. overall3. model3.1 low rank parametrized update matrices3.2 applying lora to transformer 4. limitation5. experiment6. 代码7. 补充参考文献 1. motivation 常规的adaptation需要的微调成本过大现有方法的不足: Adapter Layers Introd…...
Rust学习06:使用CSDN的AI工具“C知道”分析代码错误
朋友们,我最近真的是在绝望的边缘了! Rust咋这么蓝涅! 资料咋这们少涅! 记得学Python的时候,基本上你遇到的所有问题都可以在书上或者网上找到答案,中文世界找不到那么在英文世界一定能找到答案。 我猜&…...
MeiliSearch-轻量级且美丽的搜索引擎
MeiliSearch-轻量级且美丽的搜索引擎 MeiliSearch 是一个功能强大、快速、开源、易于使用和部署的搜索引擎。它具有以下特点: 支持中文搜索:MeiliSearch 对中文有良好的支持,不需要额外的配置。高度可定制:搜索和索引都可以高度…...
python使用wkhtmltopdf将html字符串保存pdf,解决出现方框的问题
出现的问题: 解决办法: <html> <head><meta charset"UTF-8"/> </head> <style> * {font-family: Arial,SimSun !important; } </style> </html>在html字符串前面加上上面代码,意思是设…...
Java练习题
题目: 1. 定义长方体类Cuboid,要求如下:(1)私有成员变量包括长length、宽width和高height;(2)构造方法包括一个公共的空构造方法,一个能够初始化所有成员变量的构造方法…...
【Python/Pytorch - 网络模型】-- 手把手搭建U-Net模型
文章目录 文章目录 00 写在前面01 基于Pytorch版本的UNet代码02 论文下载 00 写在前面 通过U-Net代码学习,可以学习基于Pytorch的网络结构模块化编程,对于后续学习其他更复杂网络模型,有很大的帮助作用。 在01中,可以根据U-Net…...
Ansible-doc 命令
目录 常用参数 基本用法 查看指定模块的文档 列出所有可用模块 搜索模块 显示模块参数的简单列表 显示详细的说明和示例 详细示例 查看 file 模块的文档 简略查看 copy 模块的参数 ansible-doc 是 Ansible 中的一个非常有用的命令行工具,它可以帮助你查找…...
面试题:什么是线程的上下文切换?
线程的上下文切换是指在操作系统中,CPU从执行一个线程的任务切换到执行另一个线程任务的过程。在现代操作系统中,为了实现多任务处理和充分利用CPU资源,会同时管理多个线程的执行。由于CPU在任意时刻只能执行一个线程,因此需要在这…...
【简单讲解Perl语言】
🎥博主:程序员不想YY啊 💫CSDN优质创作者,CSDN实力新星,CSDN博客专家 🤗点赞🎈收藏⭐再看💫养成习惯 ✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出…...
专硕初试科目一样,但各专业的复试线差距不小!江南大学计算机考研考情分析!
江南大学物联网工程学院,是由江南大学信息工程学院和江南大学通信与控制工程学院,于2009年合并组建成立“物联网工程学院”,也是全国第一个物联网工程学院。 江南大学数字媒体学院是以江南大学设计学院动画系和信息工程学院数字媒体技术系为…...
“华为Ascend 910B AI芯片挑战NVIDIA A100:效能比肩,市场角逐加剧“
华为自主研发的人工智能芯片——Ascend 910B,近期在世界半导体大会及南京国际半导体博览会上由华为ICT基础设施管理委员会执行董事、主任王涛发表声明称,该芯片在训练大规模语言模型时的效率高达80%,与NVIDIA的A100相比毫不逊色,且…...
针对多智能体协作框架的元编程——METAGPT
M ETA GPT: M ETA P ROGRAMMING FOR M ULTI -A GENT COLLABORATIVE F RAMEWORK 1.概述 现有的多智能体系统主要面临以下问题: 复杂性处理不足:传统的多智能体系统主要关注简单任务,对于复杂任务的处理能力有限,缺乏深入探索和…...
Django自定义CSS
创建一个CSS文件(例如admin_custom.css),并在其中添加针对你希望修改的字段的CSS规则。在你的Django项目的settings.py文件中,添加自定义CSS文件的路径到STATICFILES_DIRS。 # settings.py STATICFILES_DIRS [ os.path.join(BA…...
Rust基础学习-标准库
栈和堆是我们Rust代码在运行时可以使用的内存部分。Rust是一种内存安全的编程语言。为了确保Rust是内存安全的,它引入了所有权、引用和借用等概念。要理解这些概念,我们必须首先了解如何在栈和堆中分配和释放内存。 栈 栈可以被看作一堆书。当我们添加更…...
垂直网站导航是谁做的/免费推广app
对于 DNS 协议,你可能想知道以下几个问题:DNS 是啥DNS 服务器有哪些DNS 查询方式有哪些DNS 缓存如何提升性能DNS 协议格式长啥样DNS 有哪些安全问题DNS 的应用场景有哪些DNS 的工具有哪些01 DNS 是啥DNS 协议简单说就是为了 将用户可读的域名转换为 IP 地…...
模板网站怎么建设/连云港网站seo
1 Push SSL Certificate证书可以由admin角色生成,但是安装只能由agent安装,给provider的pem文件所用到的p12文件,也只能由agent导入后生成 以后发现角色相关问题,会继续整理汇总在这里。。。 转载于:https://www.cnblogs.com/Big…...
wordpress script/seo搜索优化专员
情景案例 其实我们身处的团队已经是非常年轻、有活力的高效合作的团队了,但是在集体工作中,有时也会出现一些问题和阻碍,如以下案例所示: 1、需求三方评审会议上,策划口若悬河,其他职能昏昏欲睡。 策划问…...
昆山做网站找文博/新东方雅思培训价目表
在这个项目上,也就是前端的工作居多。某日,一友人因把文件上传到 Dropbox 而引发众怒。同时,百度网盘也越来越不好用了。我随意吐槽之。于是乎,就有了这个项目。 某个周六深夜,写小程序已闷死,突然想起答应…...
东莞网站建设服务商/seo在线优化排名
开发前言 环境配置参考: Ubuntu20.04下ESP32环境搭建 VSCode开发配置(使用本地已经存在的配置) 搭建环境、编译烧写 VSCode运行 hello world 常用的插件命令: Show Examples Projects :查找例子 Build your project:编…...
商会网站建设/域名注册服务商
解决方法如下:第一种使用iframe,但是目前使用iframe的人已经越来越少了,而且iframe在不同浏览器之间还有不兼容的情况。而且我一些研发的人员,他们表示iframe窗口间传值似乎很麻烦。第二种使用jQuery的onload方法加载页面…...