【MYSQL数据库相关知识介绍】

news2025/1/9 15:50:41

MySQL 在我们日常技术中是一个广泛使用的开源关系型数据库管理系统,所以作为测试同学,掌握mysql的相关知识是必不可少的技能之一,所以小编从软件测试的角色出发,来整理一些跟测试相关的知识,希望能够帮助到大家。

一、基础操作

1、库的常见操作方式(DDL)

DDL(Data Definition Language) : 数据定义语言,用来定义数据库对象:数据库,表,列等

1、mysql [-h服务器地址] [-Pmysql端口][-u用户名]  [-p密码]---mysql在服务器的链接方式
eg:mysql -h192.168.193.32 -P3306 -u'work' -p'12345';
2create database my_db character set utf8;--- v忽视那个几十年一个人支持中文数据的数据库
3show databases;---查看所有数据库
4use 库名;----选择需要连接的数据库
5alter database 数据库名 modify name=新的数据库名;--修改数据库名
6drop  database 库名;--删除数据库
7、mysqldump -u root -p db1 > /tmp/db1.sql;---将db1库备份到db1.sql文件中
8、mysql -u root -p db2 < /tmp/db1.sql;--导入备份的文件到db2库中

2、表的常见操作方式(DDL)

MYSQL 数据类型:

数值:
tinyint : 小整数型,占一个字节,范围(-128127int	: 大整数类型,占四个字节,范围
	eg : age int
bigint:大整数类型,占八个字节 
    eg: id bigint
double : 浮点类型,双精度,16位精度8字节
	使用格式: 字段名 double(总长度,小数点后保留的位数)
	eg : score double(5,2) 
float:浮点类型,单精度,8位精度4字节
    eg : score float(6,3) 
日期:
date : 日期值,占3字节;只包含年月日,2024-12-01;
	eg :birthday datedatetime : 混合日期和时间值。包含年月日时分秒,2024-12-01 22:06:44
time:时间值:只包括时分秒。12:25:36
timestamp:自动存储记录修改时间
字符串:
char : 定长字符串,最多255个字符
	优点:存储性能高
	缺点:浪费空间
	eg : name char(10)  如果存储的数据字符个数不足10个,也会占10个的空间
varchar : 变长字符串,最多65535字符,存储实际字符数+1字节
	优点:节约空间,比text查询速度快
	缺点:存储性能底
	eg : name varchar(10) 如果存储的数据字符个数不足10个,那就数据字符个数是几就占几个的空间	
text:可变长度,最多65535字符,大小写不敏感,存储实际字符数+2字节,常用于存储长篇文章,日志文件,html代码等大量文本数据
     eg:content text not null;

MYSQL表基本语句

1create table class(sno int(11) primary key auto_increment,name varchar(32) not null,score float,phone int,addr varchar(32));--创建一个数据表,其中sno为主键,并且自增,name不为空
2show tables--查看当前库下的所有表
3desc class;----查询表中字段的类型设置;
4show create table class\G;---查看当前表格的字段设置;
5alter table class modify column addr int comment '详细地址';----修改列的备注信息
6alter table class change name s_name varchar(30);---修改表中name字段为s_name字段
7alter table class add age int;---在表中添加一列age字段
8alter table class drop age;--删除某列字段
9alter table class modify addr varchar(32) after name;--调整列的顺序,将addr字段调整到name字段之后,如果使用first 则表示调整该字段到表的第一列
10show procedure status where Db=database()\G-----查找当前表的所有存储过程
11show create procedure p_test\G ----查找指定的存储过程
12drop table class;--删除表

3、数据的常见操作方式(DQL/DML)

DQL(Data Query Language) 数据查询语言,用来查询数据库中表的记录(数据)
DML(Data Manipulation Language) 数据操作语言,用来对数据库中表的数据进行增删改

1insert into class (name,score,phone,addr)values('test',89.9,19900001111,'北京市朝阳区新城小区')--在表中插入一条语句
2select distinct 列名 [as 别名] [,...n]|*|表达式
             ->from 表名[,...n]
             ->[where 条件表达式]
             ->[order by 列名] desc(倒排) asc(默认正)
             ->[group by 列名]
             ->[having 条件表达式] ----查询语句
3update 表名 set 列名=[where 条件表达式];---根据where条件修改数据内容,如果不加where直接修改全部信息
4select top 3 * from class;或者 select * from class limit 13 ---限制查询前三条
5、相关聚合函数:avg(expr)  count(expr) sum(expr) max(expr) min(expr)
select 学生号 from 学生表 group by 学生号 having count(课程名)>3 ---查询选修了3门以上课程的学生学生号
select count(name),sex form 学生表 group by sex---统计男女生各多少名
select name from 学生表 group by name having count(name)>1---统计重名的名字
6select * from user where name like '%四%' or name like '%五%'---模糊匹配(%在哪就是哪匹配)
7select * from user where name like ‘张__’--严格匹配,_占一个字符
8select * from user where name regexp '四|五'--正则进行匹配
9select * from class where score between 60 and 80--查询范围 在(60,80] 的成绩信息  
10select * from exam where english > math ;--查询英语成绩大雨数据成绩的信息(多列比较)
11select * from class where age in (19,20,22);--查询年龄等于19或者20,或者22的同学(离散查询)
12delete  from class where age=12;--删除表里特定数据
13select * from class limit 5 offset 2;--分页查询,从第3条开始查询,展示5条数据
14update exam set math=math+5 order by english+math limit 3;--将成绩表中的数据成绩统一都加5,然后根据英语和数据成绩的总和进行排序,并返回前三名

二、建表的三大范式

1、第一范式(1NF)

描述: 数据表中的每一列(每个字段)必须是不可分割的最小单元,也就是确保每一列的原子性。
举例: address中字段的值:中国陕西省西安市临潼区
可拆分为国家、省、市、区四个字段
作用: 第一范式设计的越详细对后期迭代更有利
缺点: 如果需求需要返回整体的详细信息,需要按照业务需求进行各个字段的拼接操作

2、第二范式(2NF)

描述: 在满足第一范式的前提下,除了主键以外的其他列必须完全依赖于主键。如果有一个列只依赖于主键的一部分,那么它不满足第二范式。
举例:
满足第二范式:表一:【产品id,产品名】;表二:【客户id,客户名】;表三:【订单id,产品id,客户id】
不满足第二范式:表一学生成绩表:【学号、姓名、课程、学分、成绩】–姓名跟课程没有关系,学分跟学号没有关系。
不满足第二范式会带来的问题:
1.数据冗余:
学生姓名、课程、学分都重复出现,造成了大量的数据冗余。
2.更新异常:
如果需要调整JAVA的学分,那么就需要更新所有记录关于JAVA的记录,如果一旦某些记录更新成功,某些更新失败,就会造成数据中某一课程学分不一致的情况,表现为数据不一致
3.插入异常:
如果想要新增一门课程,需要为每个同学都插入一条成绩为空的数据,这样没有任何意义
4.删除异常
学生毕业之后,把毕业的同学考试记录全部都删除之后,删除记录的同时,也可能把课程对应的学分全部删除,导致一段时间内,数据库中没有课程和学分的相关信息。

3、第三范式(3NF)

描述: 在满足第二范式的前提下,除了主键以外的其他列必须直接依赖于主键,不能存在传递依赖。即,非主键列必须直接依赖于主键,不能依赖于其他非主键列。
举例:
满足第三范式:
不满足第三范式:表一:【订单id、产品id、客户id、客户电话】
在这个表中,订单id跟客户id具有强关系,客户id跟客户电话强相关;
订单id-> 客户id-> 客户电话
这样的一个传递关系,称为传递依赖,这种设置不满足第三范式,因为存在传递依赖。
解决方案: 将传递的信息单独拆出一个独立的表
需要将客户电话单独拆出一个表:表一【订单id、产品id、客户id】; 表二:【客户id、客户电话】
作用:
第三范式可以解决数据冗余,更新异常,插入异常,删除异常的问题。

第三范式在我们日常开发和测试中,经常容易被忽视,下面一个就是我们业务中不满足第三范式的数据表。
在这里插入图片描述

三、索引

描述:
索引就是一种将数据库中的数据按照特殊形式存储的数据结构。
索引是一个排好序的列表,在这个列表中存储着索引的值和包含这个值的数据
所在行的物理地址。
为什么索引查询快:
这是因为使用索引后可以不用扫描全表来定位某行的数据,
而是先通过索引表找到该行数据对应的物理地址然后访问相应的数据
索引的优缺点:
在这里插入图片描述

1、常见的索引

主键索引

是一种特殊的唯一索引,一个表只能有一个主键,
不允许有空值。一般是在建表的时候同时创建主键索引

# 在创建表的时候,直接在字段名后指定 primary key
create table class(id int primary key, name varchar(30));

# 在创建表的最后,指定某列或某几列为主键索引
create table class(id int, name varchar(30), primary key(id));

# 创建表以后再添加主键
create table class(id int, name varchar(30));
alter table class add primary key(id);

主键索引的特点:
1、一个表中,最多有一个主键索引,当然可以使复合主键
2、主键索引的效率高(主键不可重复)
3、创建主键索引的列,它的值不能为null,且不能重复
4、主键索引的列基本上是int

唯一索引

索引列的值必须唯一,但允许有空值

# 在创建表的时候,直接在字段名后指定 unique
create table class(id int primary key, name varchar(30) unique);

# 在创建表的最后,在表的后面指定某列或某几列为unique
create table class(id int primary key, name varchar(30), unique(name));

# 创建表以后再添加主键
create table class(id int, name varchar(30));
alter table class add unique(name);

普通索引

是最基本的索引,它没有任何限制

create table class(id int primary key,
	name varchar(20);
	index(name) --在表的定义最后,指定某列为索引
);

create table class(
	id int primary key, 
	name varchar(20);
	);
--创建完表以后指定某列为普通索引
alter table class add index(name); 

create table class(
	id int primary key, 
	name varchar(20);
-- 创建一个索引名为 idx_name 的索引
create index idx_name on class(name);

普通索引的特点:
一个表中可以有多个普通索引,普通索引在实际开发中用的比较多
如果某列需要创建索引,但是该列有重复的值,那么我们就应该使用普通索引

组合索引

多个字段上创建的索引
创建:create index 索引名 on 表名(字段1,字段2)
或 alter table 表名 add index 索引名(字段1,字段2)

create table class(
	id int, 
	name varchar(20);	
	);
CREATE INDEX idx_name_date ON class (id, name);

全文索引

主要用来查找文本中的关键字,而不是直与索引中的值相比较。fulltext索引配合match against操作使用,而不是一般的where语句加like

CREATE FULLTEXT INDEX content ON articles (content);

2、索引查询方式

查看表的索引方式:

show index from 表名

查看sql是否用到索引

explain select * from 表名
在这里插入图片描述

其中type字段中常见的几种情况:

	system>const>eq_ref>ref>range>index>all
	越大性能越好
		实际业务中system和const很难实现,一般能实现到rep和range

system
只有一条数据的系统表或衍生只有一条数据的主查询
const ( explain select * from order where order_id = 1 )
仅仅能查询到一条数据的sql,用于Primary key 和unique索引
eq_ref
唯一性索引:对于每个索引键的查询,返回匹配有且有一条数据
ref ( explain select * from order where deleted_at = ‘’ )
非唯一性索引:对于每个索引键的查询,返回匹配0或多行数据
Range
检索指定范围的行,where后面是一个范围查询
如:between ,>,<
in 有时会失效,从而为all
explain select * from order where deleted_at > ‘2022-04-14’
explain select * from order where deleted_at in (‘2022-03-01’,‘2021-04’)
index
查询全部索引中的数据
explain select deleted_at from order
all
查询全部表的中数据

3、删除索引

# 删除主键索引: 
alter table 表名 drop primary key;

# 其他索引的删除: 
alter table 表名 drop index 索引名; 
索引名就是show keysfrom 表名中的 Key_name 字段

# 第三种方法方法: 
drop index 索引名 on 表名

4、 避免索引失效的原则

1.复合索引不要跨列或无序使用
2.不要在索引上进行任何操作(计算,函数),否则索引失效
	如where num*3 = 15
3.复合索引不能使用(!=>,<,is null),否则自身及右侧索引全部失效
4.like尽量以常量开头,不要以%开头,否则索引失效;eg:explain select id,name,from class where name like '% 初级%';
5.尽量不要使用类型转换(显示、隐式),否则索引失效
	如where name = 123,name字段为varchar类型,程序底层将123 => '123',即进行了数据转换
6.尽量不要使用or,否则索引失效(但是使用or并不是一定会使索引失效,你需要看or左右两边的查询列是否命中相同的索引。 )
      where user_id = 1 or user_id = 2      where user_id = 1 or age = 2
7.In可能会使索引失效; eg: explain select id,name from class where name in('英语''数学');
8.不使用Select * ;eg: explain select * from class;
9. 字符串不加单引号;eg:explain select id,name from class where name=123;

四、事务

1、什么是事务?

一个最小的不可再分的单元;可以理解为一个事务对应的是一组完整的业务,并且在这个事务中所作的一切操作要么全部成功,要么全部失败,只要有一个操作没成功,整个事务都将回滚到事务开始前。
在这里插入图片描述

2、事务的特征(ACID)

原子性

每一个事务都是一个不可再分的工作单位,事务中包括的操作要么都做,要么 都不做。不会结束在中间的某个环节,如果中间有错误,会被回滚到事务开始前的状态

一致性

对于数据的操作从一个一致的状态转变成另一个一致转态。

隔离性

指一个事务的执行不能被其他事务干扰,即一个事务内部的操作对并发的其他事务是具有隔离的,并发执行的各个事务之间不能互相干扰。
在使用并发事务时,常见的问题有哪些?

1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据
2、不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。
3、幻读:一个事物内多次执行同一条sql,返回的结果集不一样。 比如一条select语句执行两次,第二次返回了第一次查询不存在的数据。
4、丢失修改(Lost to modify): 指在一个事务读取一个数据时,另外一个事务也访问了该数据,那么在第一个事务中修改了这个数据后,第二个事务也修改了这个数据。这样第一个事务内的修改结果就被丢失,因此称为丢失修改。 例如:事务 1 读取某表中的数据 A=20,事务 2 也读取 A=20,事务 1 修改 A=A-1,事务 2 也修改 A=A-1,最终结果 A=19,事务 1 的修改被丢失。

注意:不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要间隙锁+MVCC

事务隔离分为不同级别,包括读未提交,读提交,可重复读,和串行化
在这里插入图片描述

持久性

一个事务一旦提交,他对数据库中的数据的改变就应该是永久性的。提交后的其他操作或故障不会对其具有任何影响。

3、事务的控制语句


    BEGINSTART TRANSACTION# 显式地开启一个事务。

    COMMIT 或 COMMITWORK:# 提交事务,并使已对数据库进行的所有修改变为永久性的。

    ROLLBACKROLLBACK WORK# 回滚会结束用户的事务,并撤销正在进行的所有未提交的修改。

    SAVEPOINT S1: 使用SAVEPOINT #允许在事务中创建一个回滚点,一个事务中可以有多个SAVEPOINT;“S1”代表回滚点名称。

    ROLLBACK TO [SAVEPOINT] S1:# 把事务回滚到标记点。


使用set设置控制事务

 
set AUTOCOMMIT=0;       #禁止自动提交(仅针对当前会话)
set AUTOCOMMIT=1;       #开启自动提交(仅针对当前会话),Mysql默认为1  
set global AUTOCOMMIT=0;    #禁止自动提交(针对全局事务)
set global AUTOCOMMIT=1;    #开启自动提交(针对全局事务),Mysql默认为1  
show variables like 'AUTOCOMMIT';   #查看当前会话的AUTOCOMMIT值
show global variables like 'AUTOCOMMIT';  #查看全局事务的AUTOCOMMIT值 - 如果没有开启自动提交,当前会话连接的mysql的所有操作都会当成一个事务直到你输入`rollback; 或 commit;`当前事务才算结束。当前事务结束前新的mysql连接时无法读取到任何当前会话的操作结果。 - 如果开起了自动提交,mysql 会把每个sql 语句当成一个事务,然后自动的commit。 - 当然无论开启与否,`begin; commit | rollback;` 都是独立的事务。 

五、锁机制

锁是计算机中多个进程或者线程并发访问某个资源的一种机制,对于数据来说,如何保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。锁按照级别分为共享锁(S锁)和排他锁(X锁)

1、共享锁(S锁)共享锁是指多个事务可以同时申请加锁,且不会因为其他事务的共享锁而被阻塞。在共享锁存在的情况下,其他事务可以读取数据,但不能修改数据。当事务需要修改数据时,必须等待其他事务释放共享锁或者升级为排他锁。共享锁用于保证并发读取数据的一致性,提高系统读取吞吐量。
2、排他锁(X锁)排他锁是指只有一个事务可以申请加锁,其他事务必须等待该事务释放锁后才能访问数据。在排他锁存在的情况下,其他事务既不能读取数据,也不能修改数据。排他锁用于保证数据的完整性和可靠性,防止多个事务同时修改同一数据而导致数据不一致。

按照锁的粒度分为:全局锁,表级锁,行级锁。

1、全局锁

全局锁就是锁定数据库中的所有表,其使用场景是做全库的逻辑备份,需要对所有表进行锁定,从而保证数据的完整性,避免在备份过程中,其他相关联的表有数据上增删改操作,导致不同关联表之间的数据不一致。
加上全局锁后,数据库处于只读状态,整个数据库只能进行DQL语句,不能进行DDL和DML操作。

操作方式:

flush tables with read lock---加全局锁
mysqldump -uroot –p1234 class > class.sql---数据备份
unlock tables;--释放锁

2、表级锁

表级锁每次操作锁住当前整张表,表锁通常用于对表进行DDL操作或者备份等需要操作整张表的情况。

操作方式:

show open tables--查询表的加锁情况
lock tables 表名 read/write ---表加锁
unlock tables --释放锁

表锁类型的举例说明:
在这里插入图片描述

3、行级锁

行级锁是mysql中锁粒度最细的一种锁,表示只对当前操作的行进行加锁,常应用于事务中
优点:能大大减少数据库操作的冲突
缺点:加锁粒度小,开销大
对于行级锁住要分为行锁、间隙锁、临键锁三种形式。
注意事项:

1、如果sql中没有用到索引或者索引失效时,则行锁会转换为表锁
2、commint和rollback相当于解锁
3、行级的一种特殊情况,间隙锁:eg:where id>3 and id<10 ,但是如果表中没有id=7的数据,系统会自动给id=7的数据加上间隙锁
4、普通的select语句不会加锁,但是如果select ......in share mode;【共享锁】;select ......for update;【排他锁】

操作方式:

select * from class where id=1 for update;--会对id=1的数据行加上X锁(排他锁:阻止其他事务对数据行进行读取或者写入操作)
select * from class where id=1 lock share mode;--给id=1的数据行加上S锁(共享锁:允许其他事务并发的读取相同的数据,但是阻止其他事务对数据进行写操作,保证读取数据不会被修改)
在执行updatedelete等修改数据操作时,mysql会自动为设计的数据行加上X锁
show status like '%innodb_row_lock%';--查看行锁的加锁情况:innodb_row_lock_current_waits(当前正在等待锁的数量);innodb_row_lock_time(系统启动至今一共等待的时间);innodb_row_lock_time_avg(从系统启动至今平均等待的时间);innodb_row_lock_time_max(从系统启动至今最大一次等待的时间);innodb_row_lock_waites(从系统启动至今平均等待次数)

事务与锁的结合应用:

begin; 
select * from  test where id = 1 for update;
commit;
select * from  test;

begin;
update test set money ='0' where id =1;
select * from  test;
commit;

对应不同颗粒的锁对应的优缺点:
在这里插入图片描述

六、慢sql分析

在我们日常测试中,慢sql也是影响我们系统性能的因素之一,所以作为测试,我们也是需要了解慢sql的相关知识;mysql提供一种日志查询,用于记录mysql中响应时间超过阀值的sql语句

1、慢查询分析步骤

1、开启慢查询日志,观察哪些sql比较慢

通过show variables like '%query%'查看query相关的配置:

    long_query_time: 用于设置慢查询记录的阈值,单位秒,默认值为10。
    show_query_log: 是否启用慢查询日志记录,默认为OFF。
    slow_query_log_file: 配置慢查询日志信息记录路径。

1、开启慢查询日志:
通过show variables like '%query%'查看query相关的配置:

long_query_time: 用于设置慢查询记录的阈值,单位秒,默认值为10。
show_query_log: 是否启用慢查询日志记录,默认为OFF。
slow_query_log_file: 配置慢查询日志信息记录路径。

1、慢查询日志的开启与关闭
	查看是否开启
		 show variables  like  '%slow_query_log%'                    (slow_query_log_file为日志存放的路径)
	临时开启
		set golbal  slow_query_log = 1;       1=on, 0=off
			重启服务后失效 service  mysql  restart
	永久开启
		/etc/my.cnf中追加配置
			vi /etc/my.cnf
			[mysql]slow_query_log=1slow_query_log_file=路径
2、阀值的查看与设置
	查看阀值
		查看是否开启
			show variables  like '%long_query_time%'
	临时设置阀值
		set golbal  long_query_time = 5;       
			重新登录后失效 exit
	永久开启
		/etc/my.cnf中追加配置
			vi /etc/my.cnf
			[mysql] long_query_time = 5
3、慢查询sql查看
	查看慢查询sql 的条数
		show global status like '%slow_query%'
	具体查询那条慢查询sql
		日志中查询
		mysqldumpslow工具查看
		

2、Explain和慢查询SQL分析

explain select * from class where id=1

explain分析方式可以参考索引部分内容讲解。

3、使用show processlis 更近一步分析SQL的执行细节
show processlist;–通过该命令可以实时查看sql的执行时长
sql的具体响应时间
profiles 记录每条sql 的实际响应时间
set profiling = on 设置打开,默认为关闭
show profiles 查看每条sql 的具体详情
show profile all for query 对应的id 查看该sql 的所有硬件花费时间
show profile cpu,block io for query 对应的id 查看该sql 的cpu和io花费时
在这里插入图片描述

2、导致慢sql的原因

(1)SQL没有加索引或索引失效
(2)limit分页太深
(3)join、子查询、in太多
(4)查询了很多无用的字段
(5)查询使用了临时表
(6)锁竞争问题

3、SQL优化方案

1、减少IO次数
IO经常是数据库最容易产生瓶颈的地方,所以减少IO次数,就能有明显效果;具体操作就是无用的字段不需要返回出来,减少使用select *的查询方式,使用什么字段,就查询什么字段
只要通过“show profile for query 具体id ” 查询出来对应sending data 字段耗时最长,那就是IO问题
在这里插入图片描述

2、降低CPU计算
除了IO外,SQL优化中需要考虑的就是CPU计算优化,比如常见的order by,group by,distinct 等操作都是十分占用CPU的,所以我们尽量在写sql语句的时候避免使用这些操作,如果必须要使用到,尽量减少数据量。

那么以上就是mysql数据库的相关知识。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2250485.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数组和链表OJ题

leetcode用编译器调试的技巧 数组和链表练习题 leetcode/reverse_Link/main.c Hera_Yc/bit_C_学习 - 码云 - 开源中国 1、移除元素 ​​​​​​27. 移除元素 - 力扣&#xff08;LeetCode&#xff09; int removeElement(int* nums, int numsSize, int val) {int src 0, …

云服务器架构有什么区别?X86计算、Arm、GPU/FPGA/ASIC和裸金属全解析

阿里云服务器ECS架构有什么区别&#xff1f;X86计算、Arm计算、GPU/FPGA/ASIC、弹性裸金属服务器和高性能计算有什么区别&#xff1f;x86架构是最常见的&#xff0c;CPU采用Intel或AMD处理器&#xff1b;ARM架构具有低功耗的特性&#xff0c;CPU采用Ampere Altra / AltraMax或阿…

泽众TestCenter测试管理工具之案例库,提升测试工作的效率和质量

在当今的软件开发生命周期中&#xff0c;测试管理工具扮演着至关重要的角色。泽众TestCenter测试管理工具&#xff08;简称TC&#xff09;&#xff0c;作为一款广受好评的测试管理工具&#xff0c;凭借其强大的案例库功能&#xff0c;极大地提升了测试工作的效率和质量。 案例库…

Spring Cloud(Kilburn 2022.0.2版本)系列教程(五) 服务网关(SpringCloud Gateway)

Spring Cloud(Kilburn 2022.0.2版本)系列教程(五) 服务网关(SpringCloud Gateway) 一、服务网关 1.1 什么是网关 在微服务架构中&#xff0c;服务网关是一个至关重要的组件。它作为系统的入口&#xff0c;负责接收客户端的请求&#xff0c;并将这些请求路由到相应的后端服务…

基于单片机的多功能宠物窝的设计

本设计以STM32主控制器为核心芯片&#xff0c;它的组成元件有电机、温度传感器、时钟模块等。温度传感器的作用是采集环境温度的数据&#xff0c;时钟模块的作用是采集时间。将具体数据进行收集以后&#xff0c;主控制器将所有相关数据予以处理&#xff0c;从而将有关信息传递到…

Windows搭建MaskRCNN环境

环境&#xff1a;python3.6 1. 在miniconda上创建虚拟环境 miniconda下载地址&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/anaconda/miniconda # 创建环境 conda create -n maskrcnn python3.6 # 激活 maskrcnn 环境&#xff0c;后续操作都在这个环境下进行 conda ac…

LLM PPT Translator

LLM PPT Translator 引言Github 地址UI PreviewTranslated Result Samples 引言 周末开发了1个PowerPoint文档翻译工具&#xff0c;上传PowerPoint文档&#xff0c;指定想翻译的目标语言&#xff0c;通过LLM的能力将文档翻译成目标语言的文档。 Github 地址 https://github.…

新质驱动·科东软件受邀出席2024智能网联+低空经济暨第二届湾区汽车T9+N闭门会议

为推进广东省加快发展新质生产力&#xff0c;贯彻落实“百县千镇万村高质量发展工程”&#xff0c;推动韶关市新丰县智能网联新能源汽车、低空经济与数字技术的创新与发展&#xff0c;充分发挥湾区汽车产业链头部企业的带动作用。韶关市指导、珠三角湾区智能网联新能源汽车产业…

Zookeeper选举算法与提案处理概览

共识算法(Consensus Algorithm) 共识算法即在分布式系统中节点达成共识的算法&#xff0c;提高系统在分布式环境下的容错性。 依据系统对故障组件的容错能力可分为&#xff1a; 崩溃容错协议(Crash Fault Tolerant, CFT) : 无恶意行为&#xff0c;如进程崩溃&#xff0c;只要…

实例讲解MATLAB绘图坐标轴标签旋转

在进行绘图时需要在图片上添加上做标轴的标签&#xff0c;但是当数据量比较多时&#xff0c;例如一天24小时的数据&#xff0c;这时把每个小时显示在左边轴的标签上&#xff0c;文字内容放不下&#xff0c;因此需要将坐标轴标签旋转一定的角度&#xff0c;这样可以更好在图形上…

flutter项目AndroidiOS自动打包脚本

从业数年余,开发出身,经数载努力位项目经理,因环境欠佳,终失业.失业达七月有余,几经周转,现又从开发,既回原点亦从始.并非与诸位抢食,仅为糊口,望海涵!因从头开始,所经之处皆为新奇,遂处处留痕以备日后之需. 自动打包脚本原文地址:https://zhuanlan.zhihu.com/p/481472311 转…

免费实用在线AI工具集合 - 加菲工具

免费在线工具-加菲工具 https://orcc.online/ sql格式化 https://orcc.online/tools/sql 时间戳转换 https://orcc.online/tools/timestamp Base64 编码解码 https://orcc.online/tools/base64 URL 编码解码 https://orcc.online/tools/url Hash(MD5/SHA1/SHA256…) 计算 h…

Scala学习记录,统计成绩

统计成绩练习 1.计算每个同学的总分和平均分 2.统计每个科目的平均分 3.列出总分前三名和单科前三名&#xff0c;并保存结果到文件中 解题思路如下&#xff1a; 1.读入txt文件&#xff0c;按行读入 2.处理数据 &#xff08;1&#xff09;计算每个同学的总分平均分 import s…

第六届机器人、智能控制与人工智能国际(RICAI 2024)

会议信息 会议时间与地点&#xff1a;2024年12月6-8日&#xff0c;中国南京 会议官网&#xff1a;www.ic-ricai.org &#xff08;点击了解大会参会等详细内容&#xff09; 会议简介 第六届机器人、智能控制与人工智能国际学术会议&#xff08;RICAI 2024&#xff09;将于20…

分布式协同 - 分布式锁一二事儿

文章目录 导图Pre概述概述1. 分布式互斥和临界资源的协调2. 分布式锁的基本原理3. 分布式锁的实现方式a. 基于数据库实现的分布式锁b. 基于Redis实现的分布式锁c. 基于Zookeeper实现的分布式锁 4. 高并发场景下的分布式锁优化a. 分段锁&#xff08;Sharded Locks&#xff09;b.…

Stripe测试

通过官方提供的Stripe-cli工具进行测试。 1. 下载Stripe-cli 下载链接&#xff1a;Release v1.17.1 stripe/stripe-cli GitHub 2. 获取密钥 进入到stripe控制台测试模式 查看API密钥 3. 测试 指定您的API 私钥 stripe login --api-key sk_test_51ISwaXTwNwO1Rvw32DNG10…

Laravel8.5+微信小程序实现京东商城秒杀方案

一、商品秒杀涉及的知识点 鉴权策略封装掊口访问频次限制小程序设计页面防抖接口调用订单创建事务使用超卖防御 二、订单库存系统方案&#xff08;3种&#xff09; 下单减库存 优点是库存和订单的强一致性&#xff0c;商品不会卖超&#xff0c;但是可能导致恶意下单&#xff…

基于单片机设计了居家智能音箱系统(论文+源码)

1系统方案设计 通过需求分析本课题基于单片机的居家智能音箱系统的系统架构如图2.1所示。整个系统采用STM32F103作为控制器&#xff0c;结合LU-ASR01语音识别模块、ESP8266 wifi通信模块、OLED液晶、按键、音乐播放模块、LED灯等构成整个系统。用户可以通过按键、手机APP、语音…

Rook入门:打造云原生Ceph存储的全面学习路径(下)

文章目录 六.Rook部署云原生CephFS文件系统6.1 部署cephfs storageclass6.2 创建容器所需cephfs文件系统6.3创建容器pod使用rook-cephfs提供pvc6.4 查看pod是否使用rook-cephfs 七.Ceph Dashboard界面7.1 启用dashboard开关7.2 ceph-dashboard配置外部访问7.3 Dashboard web ad…

【大数据学习 | Spark-SQL】定义UDF和DUAF,UDTF函数

1. UDF函数&#xff08;用户自定义函数&#xff09; 一般指的是用户自己定义的单行函数。一进一出&#xff0c;函数接受的是一行中的一个或者多个字段值&#xff0c;返回一个值。比如MySQL中的&#xff0c;日期相关的dateDiff函数&#xff0c;字符串相关的substring函数。 先…