当前位置: 首页 > article >正文

MySQL增删改查操作 -- CRUD

个人主页:顾漂亮

目录

1.CRUD简介

2.Create新增

使用示例:

注意点:

3.Retrieve检索

使用示例:

注意点:

4.where条件查询

前置知识:-- 运算符

比较运算符

使用示例: 

注意点:

5.Order by 排序

使用示例:

注意点:

6.分页查询

使用示例:

注意点:

7.Update修改

使用示例:

注意点:

8.Delete删除

使用示例:

注意点:

9.截断表

使用示例:

注意点:

10.插入查询结果

使用示例:

注意点:

11.聚合函数

常见聚合函数:

12.group by分组查询

使用示例:

注意点:


 

1.CRUD简介

  • Create(创建)

  • Retrieve(读取)

  • Update(更新)

  • Delete(删除)

2.Create新增

使用示例:

use ghr;
-- create新增
drop table if exists users; -- 在创建之前添加一层校验
create table users(id bigint primary key auto_increment, -- 为id列设置自增主键name varchar(20) not null  -- 为name列设置不为空条件
);-- 显示表   -- 使用该语句前必须先使用use 语句,进入一个数据库中!!!!
show tables;-- 单行数据全插入  values 中的数据顺序必须要与列的顺序一致
insert into users values (1, '张三');  -- 注意:MySQL中的字符串需要用单引号包裹-- 单行数据指定列插入  -- values中的数据 必须要与users后面括号中的顺序一致
insert into users(id, name) values (3, '王五'); -- 多行数据指定列插入  多个数据中间用 , 分开即可 
insert into users(id, name) values (4, '赵六'), (5, '钱七');select * from users; 

注意点:

  1. 一次插入一条数据的效率高还是一次插入多条数据的效率更高?

  • 执行所有的SQL语句都会有网络开销

  • MySQL数据库在保存数据的时候也会有磁盘开销

  • 每执行一条SQL语句都需要开启一个事务,事务的开启到关闭也需要消耗资源

  • 因此:一次提交多条数据在一个可控范围内的时候,比一次提交一次数据的效率可以高一点!!

3.Retrieve检索

使用示例:

-- 检索查询
use ghr; -- 使用ghr数据库-- 首先创建表
drop table if exists exam; -- 添加校验
create table exam(id bigint primary key auto_increment,name varchar(20) not null, chinese float,math float,english float 
);-- 插入测试数据insert into exam(id, name, chinese, math, english) values 
(1, '唐三藏', 67, 98, 56),(2, '孙悟空', 87, 78, 77),(3, '猪悟能', 88, 98, 90),(4, '曹孟德', 82, 84, 67),(5, '刘玄德', 55, 85, 45),(6, '孙权', 70, 73, 78),(7, '宋公明', 75, 65, 30);-- 全列查询select * from exam;-- 指定列查询select name, chinese from exam;
select chinese, name from exam; -- 要查询的列只要在表中存在,与顺序无关-- 查询字段为表达式
# 把所有语文成绩+10
select id, name, chinese+10 as sum from exam;  -- 可以为表达式起一个别名 可以加 as 不加也可以
# 计算总成绩
select id, name, chinese + math + english as 总分 from exam;-- 为结果去重查询
select distinct math from exam;

注意点:

  • select返回的查询结果是根据查询列表中字段和表达式生成的一个临时表,并不会真正修改数据表中的值

  • select后面的查询列表中指定希望查询的列,可以是一个也可以是多个,中间用逗号隔开。指定列的顺序与表的结构无关

  • 使用disctinct去重时候,只有查询列表中所有列的值相同的时候才会判定为重复

  • 查询不加限制条件会返回表中的所有结果,如果表中的数据量过大,会把服务器的资源消耗殆尽

  • 在生产环境下,一定注意谨慎使用不加限制条件的查询

4.where条件查询

前置知识:-- 运算符

比较运算符

运算符

说明

>,>=,<, <=

与Java/c等用法相同

=

等于,对于NULL的比较不安全,比如NULL = NULL的结果还是NULL

<=>

等于,对于NULL的比较是安全的, 比如NULL <=> NULL 结果为1

!=, <>

不等于

Between A and B

匹配范围[A,B]

Value in(A, B, ....)

如果value在in中返回1,不再返回0

Is null

判断是NULL

Is not null

判断不是NULL

like

模糊匹配

运算符

说明

or

任意一个条件

and

多个条件必须同时成立

not

类似于!取反操作

使用示例: 

-- where条件查询use ghr;-- 基本查询
# 英语成绩小于60
select name, english from exam where english <= 60;
# 总成绩200分以下 -- 注意where语句中不可以使用别名
select name, chinese+math+english as 总分 from exam where chinese + math+english < 200;-- and和or    优先级 -- not > and > as 如果三者混合使用,建议加()
select * from exam where chinese > 80 and english > 80;select * from exam where chinese > 80 or english > 80;-- 范围查询select name, chinese from exam where chinese between 80 and 90;select name, math from exam where math in(78, 79, 98, 99);-- 模糊查询select * from exam where name like '孙%';
# 注意二者区别
select * from exam where name like '孙_';-- NULL的查询
# 构造数据
insert into exam values (8, '张飞', 27, 0, NULL);select * from exam where english is null;select * from exam where english is not null;# NULL 值与其他值运算结果为NULL
select name, chinese + math + english as sum from exam;

注意点:

  • where条件中可以使用表达式,但是不能使用别名

  • and优先级高于or,在同时使用的时候,建议使用小括号包裹优先执行的部分

  • NULL与任何值运算结果都为NULL

  • 过滤NULL时不要使用 =,!=,<>

5.Order by 排序

使用示例:

-- 前置知识:asc 为升序   desc为降序-- 按照英语成绩降序
select name, english from exam order by english desc;-- 查询总分,从高到低
select name, chinese + math + english as 总分 from exam order by 总分 desc; # 可以使用别名进行查询-- 去除有NULL值的排序
-- 所有英语成绩不为NULL的同学,按照语文成绩从高到低
select name, chinese, math, english from exam where english is not null order by chinese desc;

注意点:

  • 查询中若没有oder by 子句,返回的顺序是未定义的,永远不要依赖这个顺序

  • Order by子句中可以使用列的别名进行排序,注意与where进行区分

  • NULL进行排序的时候,视为比任何值都小,升序出现在最上面,降序出现在最下面

6.分页查询

使用示例:

-- 分页查询   -- 三种方案,以下三种方案查询结果都是相同的select * from exam order by id asc limit 3; -- 默认从偏移量0位置开始,查询3行数据select * from exam order by id asc limit 0,3; -- 从偏移量0位置开始查询,查询3条数据select * from exam order by id asc limit 3 offset 0;-- 从偏移量0位置开始查询,查询3条数据

注意点:

  • 分页查询可以有效控制一次返回的记录条数

  • 可以有效减少数据库服务器的压力,同时对于用户也比较友好

  • 在工作中,一定注意多使用分页查询

7.Update修改

使用示例:

-- 将孙悟空同学数学成绩变为80update exam set math=80 where name='孙悟空';-- 将总成绩倒数前3的数学成绩加上5分# 先查看原始数据
select name, chinese+math+english as sum from exam where chinese+math+english is not null order by sum asc limit 3;# 注意 where语句中不可以随意起别名
-- 错误示范select name, chinese+math+english from exam where chinese+math+english as sum is not null order by sum asc limit 3;
update exam set math=math+5 where chinese + math + english is not null order by chinese + math + english  asc limit 3;# 查看查询结果
select name, chinese+math+english as sum from exam where name in ('宋公明', '刘玄德', '唐三藏') order by sum asc;

注意点:

  • 在原值的基础上做变更时,不能使用math+=30这样的语法

  • 不加where条件时,会导致全表数据被更新,谨慎操作

  • 一般情况下类似于这样的更新update exam set math=80 where name='孙悟空';最为合适,先用where语句过滤,再进行更新

8.Delete删除

使用示例:

-- 删除表中一项数据
# 删除表中孙悟空的成绩
delete from exam where name = '孙悟空';-- 删除整张表的数据
# 准备一个测试表作为备份
create table if not exists t_delete(id int,name varchar(20)
);
# 插入被测数据
insert into t_delete(id,name) values (1, 'A'), (2, 'B'), (3, 'C');#删除表格中的数据
delete from t_delete;

注意点:

  • 如果执行delete操作不加限制条件,会将整个表中的数据全部删除,谨慎使用

  • MySQL服务如果开启了二进制日志,每一次的insert、update、delete操作都会记录在二进制日志里,如果需要恢复数据,可以读取日志中的记录,再进行反操作即可、

  • 注意delete只是删除表中的数据,并不会删除表,删除表需要用到表的操作中的drop,注意不要搞混淆

9.截断表

使用示例:

-- 创建测试表
# 检查判断
drop table if exists t_truncate;
create table t_truncate(id bigint primary key auto_increment,name varchar(20)
);# 插入测试数据
insert into t_truncate(name) values ('A'), ('B'), ('C');-- 显示建表结构 -- 以下是在命令行窗口中进行 AUTO_INCREMENT=4
mysql> show create table t_truncate;
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table      | Create Table                                                                                                                                                                                                   |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_truncate | CREATE TABLE `t_truncate` (`id` bigint NOT NULL AUTO_INCREMENT,`name` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)-- 截断表 
mysql> truncate table t_truncate;
Query OK, 0 rows affected (0.03 sec)
-- 显示截断后表的结构 发现AUTO_INCREMENT 被重置为0
mysql> show create table t_truncate;
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table      | Create Table|
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_truncate | CREATE TABLE `t_truncate` (`id` bigint NOT NULL AUTO_INCREMENT,`name` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+-- 继续写入数据 AUTO_INCREMENT为1
insert into t_truncate(name) values('d');

注意点:

  • 只能对整表操作,不能像delete一样对部分数据删除

  • 执行truncate操作时会把表的状态重置为初始状态,表中的数据也会被清除

  • 执行truncate不对数据操作所以比delete更快,truncate在删除数据的时候,不经过真正的事务,所以无法回滚

  • 会重置auto_increment

10.插入查询结果

使用示例:


-- 删除表中的重复数据
#首先创建测试表
drop table if exists t_record;
create table t_record(id int,name varchar(20)
);#插入测试数据
insert into t_record(id,name) values
(100, 'aaa'),
(100, 'aaa'),
(200, 'bbb'),
(200, 'bbb'),
(200, 'bbb'),
(300, 'ccc');# 创建一张新表,表结构与t_record相同
drop table if exists t_record_new;
create table t_record_new like t_record;# 原来表中的数据去重之后copy进入新表
insert into t_record_new select distinct * from t_record;   -- 核心步骤#新表与原来表重命名
rename table t_record to t_record_old, t_record_new to t_record; 

注意点:

  • 对于重命名表和数据表的迁移一般是由数据库管理员DBA来操作

  • 原始表中的数据一般都不会主动删除,但是真正查询时不需要重复的数据,如果每次查询都使用distinct进行去重操作,会严重影响效率。可以创建一张与t_record表结构相同的表,把去重的记录写入新表中,以后查询都从新表中查,这样真实数据不会丢失,同时也能保证查询效率

11.聚合函数

常见聚合函数:

-- count统计exam表中某一列数据的量
select count(*) from exam;
select count(math) from exam;-- 语文成绩小于50 的学生人数
select count(chinese) from exam where chinese < 50;-- sum统计某一列数据的总和
select sum(math) from exam;# 无法统计非数值列的和
select sum(name) from exam;-- avg统计某一列的平均数
select avg(math) from exam;# 统计总分平均分
select round(avg(chinese + math + english),2) as 总分 from exam ;-- 类比max、min用法与上述例子类似,此处不再一一赘述

12.group by分组查询

使用示例:

-- 准备测试表
drop table if exists emp;
create table emp(id bigint primary key auto_increment,name varchar(20) not null,role varchar(20) not null,salary decimal(10,2) not null
);# 插入测试用例
insert into emp values (1, '马云', '老板', 1500000.00);
insert into emp values (2, '马化腾', '老板', 1800000.00);
insert into emp values (3, '鑫哥', '讲师', 10000.00);
insert into emp values (4, '博哥', '讲师', 12000.00);
insert into emp values (5, '平姐', '学管', 9000.00);
insert into emp values (6, '莹姐', '学管', 8000.00);
insert into emp values (7, '孙悟空', '游戏角色', 956.8);
insert into emp values (8, '猪悟能', '游戏角色', 700.5);
insert into emp values (9, '沙和尚', '游戏角色', 333.3);-- 统计每个角色的人数
select role, count(*) as sum from emp group by role;-- 统计每一个角色的最高、最低工资、平均工资
select role, avg(salary), min(salary), max(salary) from emp group by role;-- 显示平均工资低于1500的角色和它的平均工资  -- having 语句支持别名
select role, avg(salary) as avg from emp group by role having avg < 1500; 
--  having 与 group by的顺序不可以颠倒

注意点:

  • 使用group by进行分组处理之后,对分组的结果进行过滤的时候,不能使用where子句,而要使用having子句

  • Having 用于对分组结果的条件过滤

  • where用于对表中真实数据的条件过滤

  • 在group by执行之前,where已经执行过了

相关文章:

MySQL增删改查操作 -- CRUD

个人主页&#xff1a;顾漂亮 目录 1.CRUD简介 2.Create新增 使用示例&#xff1a; 注意点&#xff1a; 3.Retrieve检索 使用示例&#xff1a; 注意点&#xff1a; 4.where条件查询 前置知识&#xff1a;-- 运算符 比较运算符 使用示例&#xff1a; 注意点&#xf…...

【算法day9】回文数-给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。

回文数 给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 回文数是指正序&#xff08;从左向右&#xff09;和倒序&#xff08;从右向左&#xff09;读都是一样的整数。 例如&#xff0c;121 是回文&#…...

RSA混合加密RSA混合加密

RSA混合加密是一种结合非对称加密&#xff08;RSA&#xff09;和对称加密&#xff08;AES&#xff09;的技术&#xff0c;通过两者的优势互补&#xff0c;实现高效且安全的数据传输。以下是详细解释和示例&#xff1a; RSA混合加密的核心原理 非对称加密&#xff08;RSA&#x…...

蛋白质功能预测论文阅读记录2025(DPFunc、ProtCLIP)

前言 最近研究到瓶颈了&#xff0c;怎么优化都提升不了&#xff0c;遂开始看点最新的论文。 DPFunc 2025.1.2 Nature Communication 中南大学 论文地址&#xff1a;DPFunc: accurately predicting protein function via deep learning with domain-guided structure inform…...

Linux网络套接字编程——UDP服务器

Linux网络套接字编程——创建并绑定-CSDN博客 前面已经介绍了网络套接字的创建和绑定&#xff0c;这篇文章会通过UDP套接字实现一个UDP服务器。 先介绍将使用的接口。 recvfrom ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,struct sockaddr *src_addr,…...

主流向量数据库对比

在 AI 的 RAG&#xff08;检索增强生成&#xff09;研发领域&#xff0c;向量数据库是存储和查询向量嵌入的核心工具&#xff0c;用于支持高效的语义搜索和信息检索。向量嵌入是文本或其他非结构化数据的数值表示&#xff0c;RAG 系统通过这些嵌入从知识库中检索相关信息&#…...

54.HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT 登录模块开发教程&#xff08;八&#xff09;&#xff1a;测试与调试技巧 文章目录 HarmonyOS NEXT 登录模块开发教程&#xff08;…...

Vue3中 ref 与 reactive区别

ref 用途: ref 通常用于创建一个响应式的基本类型数据&#xff08;如 string、number、boolean 等&#xff09;&#xff0c;但它也可以用于对象或数组 返回值: ref 返回一个带有 .value 属性的对象&#xff0c;访问或修改数据需要通过 .value 进行 使用场景: …...

结构型——装饰器模式

装饰器模式 装饰器是指能动态地为对象添加额外的功能的一种结构型设计模式。 特点 不修改原有代码的情况下&#xff0c;动态地扩展一个对象的功能。支持多个装饰器叠加使用透明性&#xff0c;装饰后的对象与原对象保持一致&#xff0c;客户端无需感知装饰过程 结构模式与实…...

在Simulink中将Excel数据导入可变负载模块的方法介绍

文章目录 数据准备与格式要求Excel数据格式MATLAB预处理数据导入方法使用From Spreadsheet模块(直接导入Excel)通过MATLAB工作区中转(From Workspace模块)使用1-D Lookup Table模块(非线性负载映射)Signal Builder模块(变载工况导入)可变负载模块配置注意事项与调试在S…...

分布式事务的产生背景及理论指导

分布式事务的产生背景 在现代互联网和企业级系统架构中&#xff0c;随着业务需求的增长&#xff0c;单体架构逐渐向微服务架构、分布式架构演进。传统单体架构下&#xff0c;事务管理相对简单&#xff0c;可以依赖数据库的本地事务&#xff08;如 MySQL 的 ACID 事务&#xff…...

动手学强化学习-记录

3.5 蒙特卡洛方法 统计每一个状态s出现的总次数和总回报&#xff0c;用大数定律&#xff0c;总回报/总次数≈状态s的期望回报 第4章 动态规划算法 策略迭代中的策略评估使用贝尔曼期望方程来得到一个策略的状态价值函数,这是一个动 态规划的过程;而价值迭代直接使用贝尔曼最…...

RocketMQ性能优化篇

在分布式消息系统中&#xff0c;RocketMQ以其高性能、高可靠性和高可扩展性而被广泛应用。然而&#xff0c;为了充分发挥其性能优势&#xff0c;需要进行一系列的性能测试和优化。本文将从性能测试方法和优化实践两个方面&#xff0c;详细介绍如何对RocketMQ进行性能优化。通过…...

C语言为例谈数据依赖性

数据依赖性&#xff08;Data Dependency&#xff09;是指程序中后续操作的计算结果或内存访问依赖于前面操作的结果。在存在数据依赖的情况下&#xff0c;编译器或处理器会保证这些操作的执行顺序&#xff0c;因此不需要显式地使用内存屏障&#xff08;Memory Barrier&#xff…...

阿里云操作系统控制台评测:国产AI+运维 一站式运维管理平台

阿里云操作系统控制台评测&#xff1a;国产AI运维 一站式运维管理平台 引言 随着云计算技术的飞速发展&#xff0c;企业在云端的运维管理面临更高的要求。阿里云操作系统控制台作为一款集运维管理、智能助手和系统诊断等多功能于一体的工具&#xff0c;正逐步成为企业高效管理…...

C++中的const与类型转换艺术

目录 强制转换 static_cast const_cast reinterpret_cast dynamic_cast const关键字 修饰内置类型* 修饰指针类型* 类比 数组指针 指针数组 函数指针 指针函数 强制转换 C语言中的强制转换在C代码中依然可以使用&#xff0c;这种C风格的转换格式非常简单 TYPE a …...

网络安全演练有哪些形式

OPENVAS使用 1、确定指定IP是否能ping通 2、创建扫描目标 3、创建扫描任务&#xff08;scan management →newtask&#xff09; 4、开始任务start 5、查看扫描细节 6、查看扫描结果&#xff0c;包含漏洞详细信息&#xff0c;亦可到处PDF文件 7、导出扫描结果报告 8、为…...

c++常用的算术生成算法

注意&#xff1a; 算术生成算法属于小型算法&#xff0c;使用时包含的头文件为 #include <numeric> 算法简介&#xff1a; accumulate //计算容器元素累加总和fill //向容器中添加元素 1. accumulate 功能描述&#xff1a; 计算区间内 容器元素…...

2011. 执行操作后的变量值

执行操作后的变量值 题目描述尝试做法推荐做法 题目描述 存在一种仅支持 4 种操作和 1 个变量 X 的编程语言&#xff1a; X 和 X 使变量 X 的值 加 1 –X 和 X-- 使变量 X 的值 减 1 最初&#xff0c;X 的值是 0 给你一个字符串数组 operations &#xff0c;这是由操作组成的…...

特辣的海藻!10

基础知识点 1.清除换行符 scan.nextInt()要加scan.nextLine()清楚换行符。 2.Map.Entry<K, V> Map.Entry是Map接口的嵌套接口&#xff0c;表示一个键值对&#xff08;Key-Value&#xff09; 常用方法&#xff1a; entry.getKey()&#xff1a;获取键 …...

SpringBoot动态加载JAR包实战:实现插件化架构的终极指南

在需要热插拔业务模块、支持灰度发布的系统中&#xff0c;动态加载外部JAR包是提升系统扩展性的核心技术。本文将手把手实现3种动态加载方案&#xff0c;包含可直接运行的SpringBoot代码&#xff0c;并深入分析类加载机制与内存泄漏预防策略。 一、动态加载的应用场景 ‌电商…...

双因素拆解法 - 分析比例型指标的因子贡献度

什么是比例型指标 比例型指标是指那些以比例或比率形式表示的指标&#xff0c;通常涉及两个相关量的比较。以下是一些常见的比例型指标的例子&#xff1a; 毛利率&#xff1a;毛利率是毛利与销售收入的比率&#xff0c;公式为&#xff1a; 毛利率 毛利 销售收入 100 % \tex…...

sqli-lab靶场学习(八)——Less26-28

前言 25关已经出现了初步的一些关键字过滤&#xff0c;通过双写可以绕过。后面的关卡&#xff0c;我们会遇到更多关键字过滤&#xff0c;需要各种技巧绕过。 Less26 第26关写了会过滤空格和注释符。有很多的答案&#xff0c;会用%a0替代空格&#xff0c;但据说这是sqli-labs部…...

Netty基础—4.NIO的使用简介二

大纲 1.Buffer缓冲区 2.Channel通道 3.BIO编程 4.伪异步IO编程 5.改造程序以支持长连接 6.NIO三大核心组件 7.NIO服务端的创建流程 8.NIO客户端的创建流程 9.NIO优点总结 10.NIO问题总结 4.伪异步IO编程 (1)BIO的主要问题 (2)BIO编程模型的改进 (3)伪异步IO编程 …...

双指针算法专题之——复写零

文章目录 题目介绍思路分析异地复写优化为就地复写 AC代码 题目介绍 链接: 1089. 复写零 思路分析 那么这道题我们依然可以使用双指针算法来解决 异地复写 先不考虑题目的要求&#xff0c;直接就地在原数组上修改&#xff0c;可能不太好想&#xff0c;我们这里可以先在一个…...

【Pandas】pandas Series last_valid_index

Pandas2.2 Series Time Series-related 方法描述Series.asfreq(freq[, method, how, …])用于将时间序列数据转换为指定的频率Series.asof(where[, subset])用于返回时间序列中指定索引位置的最近一个非缺失值Series.shift([periods, freq, axis, …])用于将时间序列数据沿指…...

python-leetcode-子数组最大平均数 I

643. 子数组最大平均数 I - 力扣&#xff08;LeetCode&#xff09; 可以使用滑动窗口&#xff08;Sliding Window&#xff09;的方法来解决这个问题。具体步骤如下&#xff1a; 先计算数组 nums 中前 k 个元素的和 sum_k&#xff0c;作为初始窗口的和。然后滑动窗口&#xff0…...

【度的数量——数位DP】

题目 分析 数位DP可以解决“区间内满足某种性质的数的个数”的问题 通常按照数位分支&#xff0c;形成一颗数位树 最左分支的值由上界值决定&#xff0c;右分支可以直接计算权重 有可能最左分支会有一个权重 代码 #include <bits/stdc.h> using namespace std;cons…...

STM32使用EXTI触发进行软件消抖(更新中)

在STM32的HAL库中&#xff0c;为了实现按键的软件消抖&#xff0c;通常需要在按键中断处理或轮询程序中加入一定的延时和状态检测逻辑。以下是一个简单的示例&#xff0c;展示了如何使用HAL库来实现按键的软件消抖。 假设你有一个按键连接到GPIO引脚&#xff0c;并且已经配置好…...

计算机操作系统进程(3)

系列文章目录 第二章&#xff1a;进程的描述与控制 文章目录 系列文章目录前言一、进程同步的基本概念&#xff1a;二、临界资源&#xff1a;总结 前言 前面我们学习了进程的定义和特征&#xff0c;进程状态的转换&#xff0c;接下来我们开始学习我们最重要的一点也是相对最难…...