【MySQL】表的约束(主键、唯一键、外键等约束类型详解)、表的设计
目录
1.数据库约束
1.1 约束类型
1.2 null约束 — not null
1.3 unique — 唯一约束
1.4 default — 设置默认值
1.5 primary key — 主键约束
自增主键
自增主键的局限性:经典面试问题(进阶问题)
1.6 foreign key — 外键约束
1.7 check约束(了解)
2. 表的设计
一对一
一对多
多对多
1.数据库约束
- 约束是数据库针对里面的数据有一定的要求,有些数据认为是合法数据,有些数据是非法数据。这里给出的一组"检验规则”。
- 数据库自动的对数据的合法性进行校验检查的一系列机制。目的是为了保证数据库中能够避免被插入/修改一些非法的数据。
1.1 约束类型
- not null — 指示某列不能存储 NULL 值。 —— 必填项
- unique — 保证某列的每行必须有(是)唯一的值,不能重复。 —— 学号,手机号,身份证号
- default — 规定没有给列赋值时的默认值。—— 默认值
- primary key — not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标识(既不能为空,也不能重复),有助于更容易更快速地找到表中的一个特定的记录。 —— 主键
- foreign key — 保证一个表中的数据匹配另一个表中的值的参照完整性。 —— 外键
- check — 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略 check子句。在mysql 5版本中,不支持,写了不会报错,但是没有实际效果。这里不做过多介绍。
设置约束条件大部分都是在创建表的时候。
1.2 null约束 — not null
创建表时,可以指定某列不为空。未指定:此时表可以随意插入空值。
可以使用 alter table给现有的表加约束,但用起来麻烦(支持的功能多),很少会使用。不做过多介绍。在创建表的时候要设计好表的属性。这里我们为了方便演示每次删了重新创建。
创建时,指定id 列为not null(不能为空),如果尝试插入或者修改为空,都会报错。
1.3 unique — 唯一约束
唯一:插入/修改数据的时候,会先查询,看看数据是否已经存在。如果不存在,就能够插入/修改成功,如果存在,则插入/修改失败。
unique没约束之前,可以插入多条重复的记录
unique约束之后,指定id列为唯一,不能插入重复记录
- 报错:重复条目。数据库怎么知道的1存在?
- 其实是在插入或者修改之前先触发一次,查询操作(正常插入直接插入,添加约束插入需要先查询一下),这里是多了个查找数据的成本。所以有unique 的约束插入/修改要比没有unique的约束插入/修改要慢一些。数据库的查询操作并不是像线性遍历的方式,一条一条的查,有更快的方式,但是还是有查询这个行为。
- 数据库引入约束之后,执行效率会受到影响,可能会降低很多。
- 意味着数据库是比较慢的系统,也比较吃资源的系统。在部署数据库的服务器,它很容易成为整个系统的“性能瓶颈"。
- 可靠数据角度:mysql数据库处理的数据多,需要更多的时间更可靠的去处理数据。俗话说慢工出细活。
- 性能效率角度:在现在很多高并发、大数据的情况下,mysql数据库的表现就差强人意了。根据实际情况,可以搭配redis数据库使用提高数据存储和访问。
1.4 default — 设置默认值
可以通过default 约束,来修改默认值。默认的默认值是空。
在insert 指定列插入的时候,其他未被指定到的列按照默认值来填充。
没有设置默认值,默认值为null
设置默认值;插入时,name列不做指定,默认值无名氏
1.5 primary key — 主键约束
- 主键,一行记录在表中的"身份标识",手机号码、身份证号码、学号等
- 要求唯一且不能为空,主键 = unique + not null ,
- 一张表里只能有一个primary key。一个表里的记录,只能有一个作为身份标识的数据。
- 创建主键的时候,可以使用一个列作为主键,也可以使用多个列作为主键(复合/联合主键,很少用)
- 看起来和not null + unique是类似的,同样对于带有主键约束的表,每次插入数据/修改数据之前要都要先查询操作,空的和重复的不会插入/修改。
- mysql会把带有unique 和 primary key的列自动生成索引,从而加快查询速度。(后续会讲解)
自增主键
如何保证主键唯一,mysql提供了一种"自增主键"这样机制。
- 主键经常会使用int / bigint类型。对于整数类型的主键,常配搭自增长 auto_increment 来使用。插入数据对应字段设置为null,mysql服务器会自动分配。从1开始,依次递增的分配主键的值。
- 自增主键 primary key auto_increment。程序猿插入数据的时候,不必手动指定主键约束的值了,不用考虑重复的情况了。
给自增主键插入数据的时候,可以手动指定一个值,也可以让mysql服务器自行分配。如果让mysql服务器自行分配,在insert语句的时候,把id设为null 即可了。
mysql服务器自行分配:在insert语句的时候,把id设为null 即可了。
自增主键可以理解为:mysql服务器给每个表维护了一个全局变量,每次自行分配一个id,全局变量自增,下次分配接着上次的继续分。
手动指定:
- 分配的时候把4-99序号跳过了,浪费了一部分序号,但没浪费空间。
- 这里手动指定是可以插入4-99序号,但是mysql服务器不能自动分配4-99序号。
- 如果mysql重复利用了中间的值,增长一定数据之后,就可能和100重复,因此mysql就需要时刻记得当前哪些id被分配了,哪些是空闲的,这么搞也能实现,太麻烦,效率也低。
- 自增主键,相当于使用了一个变量,来保存了当前表的id的最大值,后续分配自增主键都是根据这个最大值来分配的。如果手动指定 id,也会更新最大值。
自增主键的局限性:经典面试问题(进阶问题)
- 此处这里自增主键 自动分配 id,是有一定局限性的。
- 自增主键在单个mysql服务器,能很好的使用。
- 如果是一个分布式系统,有多个mysql服务器构成的集群,这时依靠自增主键就不行了。
- 面临的数据量大(大数据),客户端的请求量比较大(高并发),一台服务器存储管理不下,需要多台机器(分布式)。例如某一个表或者某几个表,数据量特别大。此时来了一个新的商品,进行分库分表。此时新增商品,id如何分配呢?肯定是要把这个记录保存在某个数据库的表中,但是如何保证这里的id和另外两个数据库中id不重复呢?
- 分布式系统中生成唯一 id的算法,实现这个算法的具体方式有很多,我们通过下面公式思想实现。
- 分布式唯一id = 时间戳 + 机房编号/主机编号 + 随机因子
- +是指字符串拼接,不是算术相加。拼出来的结果是一个比较长的字符串。
公式解读:
- 时间戳:如果添加商品的速度比较慢,直接使用时间戳表示就够了,
- 机房编号/主机号:但如果一个时间戳内,添加了多个商品,添加的多个商品,是要落到不同的主机上的。保证同一时间之内,添加到不同主机上的商品的编号,是不同的了。
- 随机因子:同一个ms之内,给同一个机器上添加的多个数据。随机因子这里有一定概率生成相同的因子,但是概率比较小,可以忽略不计。
1.6 foreign key — 外键约束
描述两张表之间相互关联,这个关联就是外键约束。外键用于关联其他表的主键或唯一键。
- 保证指定父表的列是带索引的。创建主键约束(PRIMARY KEY)、唯一约束(UNIQUE)、外键约束(FOREIGN KEY)时,会自动创建对应列的索引。
- 外键约束位置是在描述完,全部列之后写的。前面其他约束则是紧跟对应列的后面。
先创建两张表,class、student。
- 如果不写外键约束,此时student中的classId列与class中的classId列将没有任何关联。
- references,JavaSE中引用(类型),此处表示了当前这个表的这一列中的数据,出自于另一个表的哪一列。
- 此时student表中classId列的每行记录,都在class表的classld列中存在。
- class表中的数据,约束了 student表中的数据。
- 把class表称为“父表”(parent),约束其它表的表。
- 把student表称为“子表”(child),被其它表约束的表。
- 指定外键约束的时候,要求父表中被关联的这一列,是主键或者是unique约束的。否则子表不能关联到该列,会报错。
- 班级表为空,插入学生记录不会成功,报错;要插入的外键在关联表中没有。
- 这里不仅对插入有约束,还有修改也有约束
- 插入记录到班级表中
- 插入记录到学生表中,mysql会先拿着这个记录的classld(外键约束)1,查看class表中classId有没有,有则完成后续的插入,没有插入失败。
这里注意,studentId 为 2 ,是因为前面尝试插入了一次,没成功,但是自增主键增了。
- 修改学生表中记录,mysql会先拿着这个记录的classld(外键约束)10,查看class表中classId有没有,有则完成后续的插入,没有插入失败。要修改的外键在关联表中没有。
- 针对子表进行插入/修改操作,会先查看当前插入/修改的被约束的值,是否在父表中存在,有则完成后续的插入/修改,没有插入/修改失败。但可以修改其它没有约束的列。
- 外键约束始终要保持,子表中的数据在对应的,父表的列中要存在。
父表在约束子表,子表也反向的约束了父表
- 针对父表进行修改/删除操作,如果当前被修改/删除的值,已经被子表引用了,这样的操作也会失败。但可以修改该记录其它列。或者也可以修改/删除其它没有被反向约束的记录。外键准确来说,是两个表的列产生关联关系。其他的列是不受影响的。
- 例如:尝试删除班级表里面的classld为1的记录,发现删除失败。但可以修改该记录的className。或者可以修改/删除其它没有被反向约束的记录。
报错原因:要删除的记录关联到了其他表作为了外键,不能删除。
- 直接尝试drop table class 来删除表,也是不行的。要想删除表,也需要先删除记录。
- 正确的做法:先删除子表,然后再删除父表。
关于外键约束生活中的问题:
现在有一个电商网站,有个商品表(父表),订单表(子表),其中关于goodsId列外键约束关联。
有下面情景:一段时间后,商家想把这个衬衫给下架(删除掉),要如何完成删除。尝试删除父表数据的时候,如果父表的数据被子表引用,是不能删除的,会报错。电商网站如何做到,保证外键约束存在的前提下,实现"商品下架"功能的。
解决方法:
给商品表新增一个单独的列,表示是否在线。(不在线就相当于下架了)
如果需要下架商品,使用update把 isOk 从1 修改为 0即可。此时实现下架并非是delete 而是 update 把是否下架字段进行修改。
查询商品的时候,都加上where isOk = 1这样的条件。如果为0,就间接实现了商品下架。
了解:
- 我们在这里删除都是逻辑删除,把这个数据标记成无效,而不是直接把数据抹掉。
- 电脑上删除文件,也是通过逻辑删除的方式实现的。这样的删除数据还在硬盘上,只不过是被标记成无效了。后续其他文件是可以重复利用这块硬盘空间的。
- 通过扔进回收站,清空回收站是不能把电脑的某个文件彻底删除的。硬盘上数据彻底消亡,需要时间等待后续有文件把这块标记无效的空间重复利用了才会真正消失。
- 如何才是正确的彻底删除数据的方式,通过物理删除 -》把硬盘砸了。
- 所以按照逻辑删除的思路,表中的数据是否会无限的扩张,是否就会导致硬盘空间被占满。当然会有的。通过添加硬盘(比较便宜)、增加主机(分布式)等的方式,来进一步的扩充存储空间。
1.7 check约束(了解)
MySQL使用时不报错,但忽略该约束:
2. 表的设计
根据实际的需求场景,明确当前要创建几个表,每个表的结构以及属性,这些表之间是否存在一定联系。
设计表,分两步走:
1、梳理清楚需求中的 "实体"
例如:
一般来说每个实体,都需要安排一个表,表的列就对应到实体的各个属性。
2、梳理清楚实体之间的关系,按照关系,带入到既定的公式中。
实体之间的关系,主要有三种(严格的说是四种) 一对一, 一对多 , 多对多 , 没关系。都属于设计数据库表结构的固定套路。
三大范式:
一对一
一个学生,只能有一个账号。一个账号,只能供一个学生所有。—— 1、创建一个大表,包含全部列。2、创建两个表、相互关联。
一对多
一个班级可以包含多个学生。一个学生只能处于一个班级。—— 通过外键关联,要注意谁为父表,谁为子表。
- mysql不支持数组类型,使用mysql时是用第二种方式来实现的。
- 第一种写法,可以在redis这样能够支持数组类型的数据库中使用。
多对多
一个学生可以选择多个课程。一个课程也可以提供给多个学生。—— 借助关联表
- 没关系:上述三种关系都无法套入进去。此时这样的表就完全没有关系,各自独立设计即可,不必考虑对方。
- 一般来说,只要实体和关系都明确了,此时表的设计就基本差不多了。如果实体比较多,关系比较复杂,可以画一个"实体关系图"(ER图),来表示这个关系。
- 实际开发中,很少会画ER图。即使画也不必严格的遵守ER图的语法,大概画一下就行。
好啦Y(^o^)Y,本节内容到此就结束了。下一篇内容一定会火速更新!!!
后续还会持续更新MySQL方面的内容,还请大家多多关注本博主,第一时间获取新鲜的知识。
如果觉得文章不错,别忘了一键三连哟!
相关文章:
【MySQL】表的约束(主键、唯一键、外键等约束类型详解)、表的设计
目录 1.数据库约束 1.1 约束类型 1.2 null约束 — not null 1.3 unique — 唯一约束 1.4 default — 设置默认值 1.5 primary key — 主键约束 自增主键 自增主键的局限性:经典面试问题(进阶问题) 1.6 foreign key — 外键约束 1.7…...
学习深度学习是否要先学习机器学习?工程师的路径选择策略
深度学习与机器学习的关系,如同摩天大楼与地基——前者是后者的高阶延伸,但能否绕过地基直接造楼?本文从技术本质、学习曲线、应用场景三个维度剖析这一关键问题。 一、技术血脉的承继关系 概念体系同源: 损失函数、梯度下降、过拟…...
高防服务器适合哪些行业使用
在当今数字化的时代,网络安全就如同城堡的城墙,而高防服务器则是这道城墙中的坚固堡垒。那么,究竟哪些行业特别需要高防服务器这位“守护天使”的庇佑呢? 首先,金融行业绝对是高防服务器的“头号粉丝”。想象一下&…...
【Docker-16】Docker Volume存储卷
Docker Volume(存储卷) 概念比喻镜像程序的光盘(安装包)容器安装并运行后的 App卷独立的文件夹或硬盘,用来保存数据宿主机装着 Docker 的电脑或服务器,是一切的基础 一、什么是存储卷? 存储卷就是将宿主机的本地文件系统中存在…...
后端如何生成验证码
目录 🔐 一、验证码类型与用途 📸 二、图形验证码的原理(Image Captcha) 🔧 核心流程 🛠️ 示例:用 Python Pillow 生成图形验证码 📱 三、数字验证码(短信/邮箱&a…...
微服务架构下数据库范式的失效与反范式设计的崛起
在传统单体应用中,关系型数据库范式设计被认为是数据库建模的黄金标准。然而,随着企业架构向分布式系统,特别是微服务架构演进,范式化数据库设计的有效性和适应性正受到前所未有的挑战。本文将深入剖析范式设计的设计哲学…...
Redis专题
前言 一:看到你的简历上写了你的项目里面用到了redis,为啥用redis? 因为传统的关系型数据库如Mysql,已经不能适用所有的场景,比如秒杀的库存扣减,APP首页的访问流量高峰等,都很容易把数据库打崩࿰…...
Vue的模板语法——指令语法
2025/4/21 向全栈工程师迈进! 一、插值语法 之前通过插值语法,其显示的效果如下。 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widt…...
【Java面试笔记:基础】1.谈谈你对Java平台的理解?
前言 Java 是历史悠久且主流的编程语言,拥有庞大的开发者群体和广泛的应用领域。通过系统学习和实践,构建扎实的 Java 知识体系,提升面试成功率 笔记核心内容 1. Java 平台的核心特性 跨平台特性:Java 的核心特性之一是“Writ…...
NestJS-Knife4j
文章目录 前言✅ 一、什么是 Knife4j?✅ 二、Knife4j 与 Swagger 对比✅ 三、NestJS-Knife4j 集成1. 安装依赖2. 配置 Swagger 与 Knife4j3. 启动应用并访问接口文档 ✅ 四、功能增强1. **接口分组**2. **请求/响应示例**3. **接口文档的美化** ✅ 五、总结 前言 N…...
Linux环境准备(安装VirtualBox和Ubuntu,安装MySQL,MySQL启动、重启和停止)
目录 安装VirtualBox和Ubuntu 安装VirtualBox 安装Ubuntu 下载Ubuntu操作系统的镜像文件 创建虚拟机 虚拟机设置 启动虚拟机,安装Ubuntu系统 Ubuntu基础设置 设置系统为中文 设置中文输入法为拼音 修改分辨率 设置缩放比例 设置息屏时间 设置root用户…...
Nebula图数据库
Nebula 通常指 Nebula Graph,是一款开源的分布式图数据库系统1。以下是其相关介绍1: 特点 高性能:能处理千亿顶点和万亿边的超大规模数据集,提供毫秒级查询延迟,在处理大规模数据时,也能维持低时延的读写和…...
基于 Vue,使用Vuex 或事件总线实现跨组件通信
在基于 Vue Element UI 的 RuoYi 系统中,如果需要在一个界面(界面 A)执行某个操作后,通知另一个界面(界面 B)刷新,可以通过 Vuex 或事件总线(Event Bus)来实现跨组件通信…...
【C++篇】string类的终章:深浅拷贝 + 模拟实现string类的深度解析(附源码)
💬 欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习! 👍 点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对C感兴趣的…...
线性DP:最短编辑距离
Dp 状态表示 f(i,j) 集合所有将A[1~i]变成B[1~j]的操作方式属性min 状态计算 (划分) 增f(i,j)f(i,j-1)1//A[i]元素要增加,说明A前i位置与B前j-1相同删f(i,j)f(i-1,j)1//A[i]元素要删除,说明A前i…...
【全网最全】23种设计模式思维导图详解 | 含React/Vue/Spring实战案例
【全网最全】23种设计模式思维导图详解 | 含React/Vue/Spring实战案例 导图概述 本文通过高清思维导图系统梳理了23种设计模式,分为创建型、结构型、行为型三大类,并标注了各模式在主流框架(如React、Vue、Spring)中的典型应用场…...
8086微机原理与接口技术复习(1)存储器(2)接口
8086微机原理与接口技术复习(1)存储器(2)接口 存储器8086的存储空间存储器的拓展存储器的分类 接口8086I/O82558253串行通信 存储器 我们上的是嵌入式与接口技术这门课,存储器章节重点在于理解8086CPU的存储体结构&am…...
第 6 篇:衡量预测好坏 - 评估指标
第 6 篇:衡量预测好坏 - 评估指标 上一篇,我们小试牛刀,用朴素预测、平均法、移动平均法和季节性朴素预测这几种简单方法对未来进行了预测。我们还通过可视化将预测结果与真实值进行了对比。 但光靠眼睛看图来判断“哪个预测更好”往往是不…...
极刻AI搜v1.0 问一次问题 AI工具一起答
软件名:极刻AI搜 版本:v1.0 功能:囊括了互联网上比较好用的一些支持”搜索“的网站或者工具 开发平台:nodepythonweb 分类有: AI搜索(支持智能问答的AI搜索引擎) 常规搜索:ÿ…...
单片机 + 图像处理芯片 + TFT彩屏 进度条控件
进度条控件使用说明 概述 本进度条控件基于单片机 RA8889/RA6809 TFT开发,提供了简单易用的进度显示功能。控件支持多个进度条同时显示、自定义颜色、边框和标签等特性,适用于需要直观显示进度信息的各类应用场景。 特性 支持多个进度条同时显示可…...
RHCSA Linux系统 用户和组的管理
用户管理:增useradd 删userdel 改usermod 查id 组的管理:增groupadd 删groupdel 改groupmod 查groups /etc/default/useradd 即定义useradd默认参数,也定义了/etc/passwd ,/etc/shadow,/etc/group&#…...
2025年pta团队设计天梯赛题解
题解不全,望见谅 L1-1 珍惜生命 题目 前辈工程师 Martin Golding 教育我们说:“Always code as if the guy who ends up maintaining your code will be a violent psychopath who knows where you live.”(写代码的时候,总是要…...
Vue---vue2和vue3的生命周期
核心生命周期对比 生命周期阶段Vue 2 钩子Vue 3 Composition API初始化beforeCreate无(使用 setup() 替代)初始化完成created无(使用 setup() 替代)挂载前beforeMountonBeforeMount挂载完成moun…...
C#常用LINQ
在开发时发现别人的代码使用到了LINQ十分便捷且清晰,这里记录一下常用LINQ和对应的使用。参考链接:LINQ 菜鸟教程 使用的学生类和字符串用于测试 public class Student {public int StudentID;public string StudentName;public int Age; }Student[] st…...
Java--数组的应用
一、数组的地址值 数组的地址值表示数组在内存中的位置。 [I1eb44e46 [ :表示当前是一个数组I:表示当前数组是int类型:表示一个间隔符号(固定格式)1eb44e46:数组真正的地址值(十六进制&#…...
PostgreSQL基础
一、PostgreSQL介绍 PostgreSQL是一个功能强大的 开源 的关系型数据库。底层基于C实现。 PostgreSQL的开源协议和Linux内核版本的开源协议是一样的。。BDS协议,这个协议基本和MIT开源协议一样,说人话,就是你可以对PostgreSQL进行一些封装&a…...
Linux系统管理与编程13:基于CentOS7.x的LAMP环境部署
兰生幽谷,不为莫服而不芳; 君子行义,不为莫知而止休。 一、实验目标 1.理解Apache服务器原理 2.掌握Apache服务器的配置文件 3.具备安装Mysql数据库能力 4.具备安装Apache服务器能力 5.具备PHP与数据库连接能力 6.具备Apache、Mysql、…...
浅谈AI致幻
文章目录 当前形势下存在的AI幻觉(AI致幻)什么是AI幻觉AI幻觉的类型为什么AI会产生幻觉AI幻觉的危害与影响当前应对AI幻觉的技术与方法行业与学术界的最新进展未来挑战与展望结论 当前形势下存在的AI幻觉(AI致幻) 什么是AI幻觉 …...
【架构】-- StarRocks 和 Doris 介绍与选型建议
StarRocks 和 Doris 的介绍 随着大数据分析需求的不断增长,企业对高性能、低延迟的分析型数据库提出了更高的要求。StarRocks 和 Apache Doris 是当前主流的开源 MPP(Massively Parallel Processing)数据库系统,广泛应用于实时分析、报表生成和数据仓库等场景。本文将从架…...
【SF顺丰】顺丰开放平台API对接(注册、API测试篇)
1.注册开发者账号 注册地址:顺丰企业账户中心 2.登录开发平台 登录地址:顺丰开放平台 3.开发者对接 点击开发者对接 4.创建开发对接应用 开发者应用中“新建应用”创建应用,最多创建应用限制数量5个 注意:需要先复制保存生产校验…...
C语言高频面试题——常量指针与指针常量区别
1. 常量指针(Pointer to Constant) 定义: 常量指针是指向一个常量数据的指针,即指针指向的内容不能通过该指针被修改。 语法: const int* ptr;或者: int const* ptr;解释: const修饰的是指…...
Novartis诺华制药社招入职综合能力测评真题SHL题库考什么?
一、综合能力测试 诺华制药的入职测评中,综合能力测试是重要的一部分,主要考察应聘者的问题解决能力、数值计算能力和逻辑推理能力。测试总时长为46分钟,实际作答时间为36分钟,共24题。题型丰富多样,包括图形变换题、分…...
网页下载的m3u8格式文件使用FFmpeg转为MP4
FFmpeg 是一个强大的开源音视频处理工具,可以直接将 M3U8 合并并转换为 MP4。 1.步骤: 下载 FFmpeg 官网:https://ffmpeg.org/ Windows 用户可以直接下载 静态构建版本(Static Build),解压后即可使用。 2…...
Java 并发包核心机制深度解析:锁的公平性、异步调度、AQS 原理全解
🧠 Java 并发包核心机制深度解析:锁的公平性、异步调度、AQS 原理全解 Java 并发编程的地基是 java.util.concurrent,但真正驱动这个系统的,是它背后隐藏的三根支柱: ReentrantLock 的公平/非公平调度策略Completabl…...
μC/OS 版本演进过程 | uC/OS-II 和 uC/OS-III 有什么区别?
uC/OS 系列是由 Jean J. Labrosse 开发的一套嵌入式实时操作系统(RTOS),以其高质量源码和清晰的结构,在嵌入式教学和某些工业项目中有着广泛影响。该系统主要包含两个版本:uC/OS-II 和 uC/OS-III。 本文将带你了解这两…...
永磁同步电机参数辨识算法--递推最小二乘法辨识
一、原理介绍 最小二乘法大约是1795年高斯在其著名的星体运动轨道预报研究工作中提出的。后来,最小二乘法成为了估计理论的基石。最小二乘法由于原理简明、收敛较快、易于编程实现等特点,在系统参数估计中应用相当广泛。 其基本原理为: 改写…...
树莓派5+L298N控制电机
准备工作: 树莓派5开发板L298N 控制板电机1个12v的电池1个杜邦线若干L298N 引脚介绍 (1)图中标注的1和2都是都在输出引脚,可以各接入一个电机,电机不分正负极,随便接 (2)图中3这里是控制板的电源输入正负极,可以输入5v和12v,我这里输入的是12v电源,使用的时候应该把…...
UofTCTF-2025-web-复现
感兴趣朋友可以去我博客里看,画风更好看 UofTCTF-2025-web-复现 文章目录 scavenger-huntprismatic-blogscode-dbprepared-1prepared-2timeless scavenger-hunt 国外的一些ctf简单题就喜欢把flag藏在注释里,开源代码找到第一部分的flag 抓个包返回数据…...
记录seatunnel排查重复数据的案例分析
文章目录 背景分析检查现象检查B集群是否有异常,导致重复消费的分析同步任务 修复问题发现flink job 一直报异常修复问题 背景 使用seatunnel 同步数据从A 集群kafka 同步到B集群kafka,现象是发现两边数据不一致,每天10w级别会多几十条数据 分析 检查…...
技术速递|Agent 模式:对所有用户开放,并支持 MCP
作者:Isidor Nikolic 翻译/排版:Alan Wang Agent 模式正在向所有 VS Code 用户推广!它充当一个自主的配对编程助手,能够根据你的指令执行多步编码任务,例如分析代码库、提出文件修改建议以及运行终端命令。它能够响应编…...
实验四 Java图形界面与事件处理
实验四 Java图形界面与事件处理 ###实验目的 掌握Java语言中AWT和Swing组件的基本用法掌握Java语言中的事件处理方法掌握Java语言中事件源、监视器和处理事件的接口的概念 ###实验内容 图形用户界面设计程序(ArtFont.java)(90分) 要求:设…...
day2 python训练营
浙大疏锦行 python训练营介绍...
Linux下 REEF3D及DIVEMesh 源码编译安装及使用
目录 软件介绍 基本依赖 一、源码下载 1、REEF3D 2、DIVEMesh 二、解压缩 三、编译安装 1、REEF3D 2、DIVEMesh 四、算例测试 软件介绍 REEF3D是一款开源流体动力学框架,提供计算流体力学及波浪模型。软件采用高效并行化设计,可以在大规模处理器…...
堡垒机和跳板机之区别(The Difference between Fortress and Springboard Aircraft)
堡垒机和跳板机之区别 在网络安全、安全运维领域,堡垒机和跳板机是两个常被提及且功能相似的概念,但它们在实际应用、功能定位以及技术实现上存在着明显的差异。本文将对堡垒机和跳板机进行详细的解析与比较,帮助读者更好地理解这两种网络安…...
《Android 应用开发基础教程》——第五章:RecyclerView 列表视图与适配器机制
目录 第五章:RecyclerView 列表视图与适配器机制 5.1 为什么要使用 RecyclerView? 5.2 基本结构图 5.3 RecyclerView 使用步骤 1️⃣ 添加 RecyclerView 依赖(Android Studio) 2️⃣ 布局文件(activity_main.xml&…...
【第四章】19-匹配规则定义
在优化Web服务器性能与增强其功能性的过程中,深入理解Nginx的location匹配规则显得尤为关键。它不仅决定了如何高效地路由不同类型的客户端请求,而且是实现精准响应的基础。通过掌握精确匹配、前缀匹配及正则表达式匹配等规则,管理员能够灵活配置以支持复杂的业务需求,同时…...
[PTA]2025CCCC-GPLT天梯赛 现代战争
来源:L1-112 现代战争-Pintia题意:给定 n m n\times m nm 的矩阵,进行 k k k 次操作,每次操作清除矩阵当前最大值所在行和所在列的全部元素,求最终矩阵。关键词:模拟(签到)题解:非常水的模拟…...
操作系统期中复习
未完待续----后续补充全书完整板 一、计算机系统概述 1.1操作系统的基本概念 1.1.1操作系统的概念 操作系统:是指控制和管理整个计算机系统的硬件与软件资源,合理地组织、调度计算机的工作与资源的分配,进而为用户和其他软件提供方便接口…...
Linux 入门十一:Linux 网络编程
一、概述 1. 网络编程基础 网络编程是通过网络应用编程接口(API)编写程序,实现不同主机上进程间的信息交互。它解决的核心问题是:如何让不同主机上的程序进行通信。 2. 网络模型:从 OSI 到 TCP/IP OSI 七层模型&…...
车载软件架构 --- 二级boot设计说明需求规范
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 周末洗了一个澡,换了一身衣服,出了门却不知道去哪儿,不知道去找谁,漫无目的走着,大概这就是成年人最深的孤独吧! 旧人不知我近况,新人不知我过…...