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

12-表的约束

知识背景

表的约束,就是在表中的数据上加上约束,也被称为数据完整性约束。数据完整性约束的目的是为了不被规定的、不符合规范的数据进入数据库

在录入数据库或数据发生变化时,DBMS(数据库管理系统)会按照一定的约束条件对数据进行监测,是不符合规范的数据不能进入数据库,使数据库中存储的数据正确、有效、相容,确保存储的数据是正确的。

在表中有三大类完整性约束:实体完整性(entity integrity)、参照完整性(referential integrity)和用户定义的完整性(user-defined integrity)

"单列约束可以定义在列级或者表级,多列约束则必须定义在表级"这是什么意思呢?

单列约束:指定是设计涉及字段(列)的约束。这类约束可以在定义字段时直接指定(即列级),例如在创建表时直接为某个字段指定NOT NULL 或 UNIQUE约束,也可以在表级别定义,即在创建表之后单独为某个字段添加约束

多列约束:涉及两个或更多字段(列)的约束,这类约束必须在表级别定义,因为他们关联了多个字段,不能仅仅在单个字段级别进行定义,如最常见的复合主键(由多个列共同作为主键)和复合外键

实体完整性约束

实体完整性的定义

1、关系型数据库中每个元组应该是可区分的,是唯一的,使用这样的约束条件来保证实体完整性

2、实体完整性约束所对应的属性被称为表的主键(primary key),或者称为关系的主码

3、实体完整性约束可以定义在表中的一列或多列上

实体完整性的规则

1、实体完整性的规则基本都是针对于表而言的,一个基本表通常对应于现实世界的一个实体集

2、主键对应的列值在表中是非空的、唯一的

3、每个表中最多只能拥有一个主键

实体完整性约束创建语法

1、定义主键约束

CREATE TABLE table_name (column1 INT,column2 VARCHAR(255),...PRIMARY KEY (column1)					//使得column1被定义为主键
);

2、定义主键约束并且给主键约束命名

CREATE TABLE table_name (column1 INT,column2 VARCHAR(255),...CONSTRAINT constraint_name PRIMARY KEY (column1)				//定义column为主键,并使这个主键被命名为constraint_name
);

3、如果表已经存在,还可以手动增加主键约束

ALTER TABLE table_name
ADD CONSTRAINT constraint_name PRIMARY KEY (column1);

参照完整性约束

参照完整性约束的定义

1、参照完整性就好像现实世界中实体与实体的依赖关系,比如鱼与水,水就是鱼的生存环境,这样的关系在数据中,表与表之间也是存在的

2、一个表的属性需要依赖于另一个表的属性,在数据库中被映射为一个表的字段与另一个表的某个字段相关联,使用这样的约束条件来保证参照完整性,例如,员工表和部门表,因为每一个入职的员工都必须要又对应的部门,当员工表中有一条员工数据是没有部门的,那么就说明这一条员工的数据是不合理的

3、 参照完整性约束对应的属性被称为表的外键(foreign key),或者被称为关系的外码

4、参照完整性约束可定义在表中的一列或者多列上

5、外键约束需要有主表和从表,如上述所说的例子,员工表就是从表,部门表就是主表(被参照的表)

参照完整性约束的规则

1、被参照的相对应列上必须被定义为主键约束或唯一约束,也就是说在主表上的被参照的字段必须被定义为主键约束或唯一约束

2、表的外键列可以取空值

参照完整性语法举例

设有两个表,分别为classes表和student表,其中classes表为主表,student表为从表,并且classes表的主键字段id被student_id字段给引用

CREATE TABLE classes (id INT PRIMARY KEY,					//被引用的字段必须被设置为主键约束或唯一约束name VARCHAR(255)
);
CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(255),class_id INT,CONSTRAINT ID FOREIGN KEY (class_id) REFERENCES classes(id)      //是class表中di字段被当前正在创建的表的class_id字段所引用,并且被命名为ID	
);

如果表已经存在还可添加外键约束

ALTER TABLE students
ADD CONSTRAINT ID
FOREIGN KEY (class_id)
REFERENCES classes(id);

在进行参照完整性的过程当中,还可进行级联操作,有更新级联和删除级联,以下这个例子就是删除级联(以DELETE为关键字,更新的关键字即为UPDATE)

CREATE TABLE classes (id INT PRIMARY KEY,name VARCHAR(255)
);
CREATE TABLE students (id INT PRIMARY KEY REFERENCES classes ON DELETE RESTRICT/CASCADE/SETNULL, //进行删除级联name VARCHAR(255),class_id INT,CONSTRAINT ID FOREIGN KEY (class_id) REFERENCES classes(id)	
);

或是

CREATE TABLE classes (id INT PRIMARY KEY,name VARCHAR(255)
);
CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(255),class_id INT,CONSTRAINT ID FOREIGN KEY (class_id) REFERENCES classes(id) ON DELETE RESTRICT/CASCADE/SETNULL
);
参数介绍
ON DELETE RESTRICT当在父表/主表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应的外键,如果有,则不允许删除
ON DELETE CASCADE当在父表/主表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有,则也级联地删除外键在子表(即包含外键的表)中的记录
ON DELETE SETNULL当在父表/主表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有,则将外键列设置为空值

用户定义的完整性约束

任何的关系型数据库都应该支持实体完整性和参照完整性,这是关系模型所要求的。除此之外,不同的关系型数据库系统根据其应用环境的不同,还需要一些特殊的约束条件。而用户定义的完整性约束就是针对某一具体关系数据库的约束条件

非空约束

概述:非空约束就是要求设置非空约束的列值不同为空值,使用NOT NULL关键字来设置

语法:

在下述的创建表的SQL语句中,"id integer NOT NULL"就是指定了t01表中id字段为非空约束

CREATE TABLE t01 (id integer NOT NULL,name text.score numeric);

唯一约束

概述:唯一约束需要保证设置唯一约束的列值是在整个列中是唯一的,但可以为空

语法:

“id integer UNQIUE”就是将id字段设置为唯一约束

CREATE TABLE t01(id integer UNQIUE,name text,score numeric);

check约束

概述:限制一个特定列中的值必须要满足一定的条件表达式,当插入数据是,DBMS将检查该数据是否满足check约束条件,当不满足时,将会拒绝这种操作

语法:

下述SQL语句中,"score numeric CHECK (score > 0)"的check约束为在插入或更新score的数据值必须大于0

CREATE TABLE t01(id integer,name text,score numeric CHECK (score > 0));

约束的控制状态

概述:

①enable/disable 对新增的数据进行检查/对新增的数据不进行检查

②validate/novalidate 对现有数据的约束检查/对现有数据的约束不检查

约束控制方法:

约束的控制方法都是,对现有的数据和对新增的数据各自执行一个策略,其中外严内峻是默认状态,如下图

image-20241117155834483

参数简介
enable+validate默认状态;对新插入的数据执行完整性约束检查,对表中现有的数据执行完整性约束检查
disable+novalidate对新插入的数据不执行完整性约束检查,对表中现有的数据不执行完整性约束检查
disable+validate对新插入的数据不执行完整性约束检查,对表中现有的数据执行完整性约束检查,不允许对表执行DML操作,即对数据进行增删查改等操作
enable+novalidate对新插入的数据执行完整性约束检查,对表中现有的数据不执行完整性约束检查

这里可能会问道,为什么在"disable+validate"的约束控制状态下,不能执行DML操作,也就是不能执行增删改等操作呢?

个人理解:我想是因为"disable+validate"这两个概念刚好起了冲突,①首先,disable是针对新增的数据进行检查。②其次,validate是针对表中已有的数据进行检查,③但是,当数据新增进来的时候,新增的数据在某一个时刻,有两种身份,即作为新增的数据,又是表中现有的数据,那么DBMS到底应不应该检查呢?所以这时就产生了矛盾,才会导致不允许执行DML操作

kimi解释:当DISABLEVALIDATE组合在一起时,由于DISABLE允许插入不符合约束条件的数据,而VALIDATE在数据变化时会检查约束条件,这会导致在插入数据时不会检查约束,但在后续的检查中发现数据不符合约束条件,从而产生矛盾和数据不一致的问题

延迟约束

1、概述:

KES支持延迟检测约束的功能,便于在数据迁移和应用数据批量导入时保证成功率和操作效率

2、deferrable(可延迟的)和not deferrable(不可延迟的),这两个选项控制了该约束是否能被延迟。一个不可延迟的约束将在每一次数据插入或修改后立刻被检查,可延迟的检查将被推迟到事务结束时进行

3、initially immediate(立即检查)和initially deferred(延迟检查),延迟判断规则,如果该定义约束时指定为initially immediate,那么它在每一次数据插入或修改后被检查,这是默认值。如果指定为intially immediate,那么它会在每一次数据插入或修改后被检查,这是默认值。如果指定为initially deferred,那么它只会在事务结束之后被检查

4、用户可以在事务中设置延迟约束的延迟属性

SET CONSTRAINTS {ALL | constraint_name[,...]} {DEFERRED | IMMEDIATE}

实验1:主键约束

t01表的结构如下图

image-20241117180905719

t02表的结构如下图

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

创建表时定义主键约束

1、在列级定义主键约束

创建t01表,并在id列上创建主键约束

test=# create table t01(id integer primary key,name text,score numeric);

2、在表级定义主键约束

将刚刚创建的t01表删除(无论是否存在的方法),创建t01表,并在id列上创建主键约束

test=# drop table if exists t01;
test=# create table t01(id integer,name text,score numeric,constraint ID primary key(id));

修改表时增加主键约束

1、将刚刚创建的t01表删除(无论是否存在的方法)

test=# drop table if exists t01;

2、创建t01表

test=# create table t01(id integer,name text,socre numeric);

3、修改t01,为id列创建主键约束

test=# alter table t01 add constraint ID primary key(id);

验证主键约束

1、往t01表插入2条id相同的数据,将会产生报错

test=# insert INTO t01(id) values (100);
INSERT 0 1
test=# insert INTO t01(id) values (100);

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实验2:外键约束

创建外键约束

1、在被参照表中创建主键约束

创建t01表,并在id列上定义主键约束,因为在外键约束的形成中,被参照表中的被引用字段需要是主键约束或唯一约束

test=# create table t01(id integer primary key,name text,score numeric);

2、在参照表中创建外键约束

创建t02表,并在no列上定义外键约束,引用t01表的id主键列

test=# create table t02(no integer,name text,constraint t02_fk foreign key (no) REFERENCES t01(id));

3、验证外键约束

往t01表插入1行数据

往t02表插入2行数据,其中1行数据违反外键约束

test=# insert INTO t01(id) values (100);
test=# insert INTO t02(no) values (100);
test=# insert INTO t02(no) values (200);

image-20241117185902873

外键约束级联控制

注:

①存在外键依赖时,不可直接对父表的主键列执行更新操作

②使用ON DELETE CASCADE 选项可以在删除父表元组时实现级联删除子表元组

③使用ON DELETE SET NULL 选项可以在删除父表元组时实现级联更新子表元组的外键列为空值

1、创建t02表,在no列上创建主键约束

test=# create table t02(no integer primary key,name text); 

2、创建t01表,在id列上创建外键约束,参照t02表的no列并设置为级联控制

test=# create table t01 (id integer,name text,score numeric,constraint t02_fk foreign key (id) references t02(no) on delete cascade);

3、往t02表中插入1条记录,往t01表中插入1条满足外键约束的记录

test=# insert INTO t02(no) values (100);
test=# insert INTO t01(id) values (100);

4、更新t02表的no字段,该操作会因存在外键关联导致更新主键列失败

test=# update t02 SET no = 200 where no = 100;

image-20241117190648328

5、删除t02表中的记录(因为子表中参照的外键设置为级联删除。所以可成功删除父表元组)

test=# delete from t02 where no=100;

6、查看t01表的记录

test=# select * from t01;id | name | score 
----+------+-------
(0 行记录)

实验3:非空约束

创建表时定义非空约束

1、创建t01表,并在id列上创建非空约束

test=# create table t01(id integer not null,name text,score numeric);

修改表时增加非空约束

1、修改t01表时,并在name列上创建非空约束

test=# alter table t01 alter COLUMN name set not null;

2、使用元命令查看t01表的结构信息

test=# \d t01数据表 "public.t01"栏位  |  类型   | 校对规则 |  可空的  | 预设 
-------+---------+----------+----------+------id    | integer |          | not null | name  | text    |          | not null | score | numeric |          |          | 

验证非空约束

1、往t01表中插入2条记录,其中1行数据违反非空约束

test=# insert INTO t01 values(100,'aaa',1);
test=# insert INTO t01 values(100,null,2);

image-20241117192408777

实验4:唯一约束

创建表时定义唯一约束

1、创建t01表,并在id列上创建唯一约束

test=# create table t01 (id integer unique,name text,score numeric);

修改表时增加唯一约束

1、修改t01表,并在name列上增加唯一约束

test=# alter table t01 add constraint un_t01 unique(name);

验证唯一约束

1、往t01表中插入2条记录,其中1行数据违反唯一约束

test=# insert INTO t01 values (100,'aaa',1);
test=# insert into t01 values (100.'aaa',2);

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实验5:check约束

创建表时定义check约束

1、创建t01表,并在score列上创建check约束,要求score取值必须大于0

test=# create table t01(id integer,name text,score numeric check(score>0));

修改表时增加check约束

1、修改t01表,并在socre列上增加check约束,要求score取值必须小于100

test=# alter table t01 add constraint check_score_t01 check(id<100);

验证check约束

1、往t01表中插入2条记录,其中1行数据违反check约束

test=# insert INTO t01(id) values (99);
test=# insert INTO t01(id) values (100);

image-20241117194325449

实验6:约束的状态控制

enable+validate

1、创建测试表t01,并为id列定义check约束,要求id列值必须大于10

test=# create table t01(id integer,name text,score numeric,constraint T01_CK check(id>10));

2、插入一条无效的数据到t01表中(执行报错)

test=# insert INTO t01(id) values (9); 
错误:  关系 "t01" 的新列违反了检查约束 "t01_ck"
描述:  失败, 行包含(9, null, null).

3、通过数据字典表(dba_constraints)查看约束的信息(constraint_name,status,validated),数据字典表示t01表时,需要使用大写,即针对T01表进行查询,

test=# select constraint_name,status,validated from dba_constraints where table_name='T01';constraint_name | status | validated 
-----------------+--------+-----------T01_CK          | ENABLE | VALIDATED
(1 行记录)

image-20241117211301673

disable+novalidate

1、修改t01表的t01_ck约束为disable novalidate

test=# alter table t01 disable novalidate constraint t01_ck ;

2、插入一条无效的数据到t01表中(执行成功)

test=# insert INTO t01(id) values (9);
INSERT 0 1

3、插入一条有效的数据到t01表中(执行成功)

test=# insert INTO t01 (id) values (11);
INSERT 0 1

image-20241117212115854

4、通过数据字典表查看约束的信息

test=# select constraint_name,status,validated from dba_constraints where table_name='T01';constraint_name | status  |  validated  
-----------------+---------+-------------T01_CK          | DISABLE | NOVALIDATED
(1 行记录)

disable+validate

1、调整约束t01_ck为disable validate状态会产生报错(因为在上面的实验中我们插入了违规数据)

test=# alter table t01 disable validate constraint t01_ck ;
错误:  一些行违反了检查约束 "t01_ck"

2、删除违规数据

test=# delete from t01 where id =9;

3、调整约束t01_ck为disable validate状态成功

test=# alter table t01 disable validate constraint t01_ck ;
ALTER TABLE

4、对t01表执行DML操作,应该是执行失败的

test=# insert INTO t01(id) values(12);  
错误:  不对表 (t01) 进行插入/更新/删除,在禁用并验证约束 (t01_ck) 的情况下
test=# update t01 SET id=12 where id=11;
错误:  不对表 (t01) 进行插入/更新/删除,在禁用并验证约束 (t01_ck) 的情况下
test=# delete from t01 where id=11;     
错误:  不对表 (t01) 进行插入/更新/删除,在禁用并验证约束 (t01_ck) 的情况下

image-20241117214042517

5、通过数据字典查看约束的信息

test=# select constraint_name,status,validated from dba_constraints where table_name='T01';constraint_name | status  | validated 
-----------------+---------+-----------T01_CK          | DISABLE | VALIDATED
(1 行记录)

enable+novalidate

1、禁用约束t01_ck(即disable+novalidate),插入一条违反约束的记录到t01表中

test=# alter table t01 disable novalidate constraint t01_ck ;
ALTER TABLE
test=# insert INTO t01(id) values (9);
INSERT 0 1

2、调整约束t01_ck为enable novalidate状态,可以发现这是修改成功的,因为只会对新增的数据进行检查,而不会对已有的违规数据进行检查

test=# alter table t01 enable novalidate constraint t01_ck ;

3、插入一条违反约束的记录到t01表中,如果不出意外的话,应该是插入失败的,因为DBMS对新增的数据进行了检查,发现新增的数据是一条违规数据,随后就被拒绝了

test=# insert INTO t01(id) values (8);
错误:  关系 "t01" 的新列违反了检查约束 "t01_ck"
描述:  失败, 行包含(8, null, null).

4、插入一条正常的记录到t01表中,当然这是会成功的

test=# insert INTO t01(id) values(12); 
INSERT 0 1

实验7:延迟约束

创建延迟约束

1、创建测试表t01,并在id列上创建主键约束

test=# create table t01(id integer primary key,name text,score numeric);      

2、创建测试表t02,并未id列定义延迟外键约束,参照t01表的id列

test=# create table t02 (id int,name text,constraint t02_fk foreign key (id) references t01(id) initially deferred);

3、显式开启事务

test=# begin ;
BEGIN

4、往子表t02中插入一条数据,执行成功,因为当前开启的事务,而当前的延迟状态时deferrable(可延迟的),可延迟的检查将被推迟到事务结束时进行

test=# insert INTO t02 values (20,'a');

5、往父表t01中插入一条数据

test=# insert INTO t01 values (20,'a',1);

6、结束事务,自动提交成功

test=# end;

7、通过数据字典表查看约束的信息

test=# select constraint_name,deferred from user_constraints where table_name='T02';constraint_name | deferred 
-----------------+----------T02_FK          | DEFERRED
(1 行记录)

在事务中控制延迟约束

在事务中执行约束,可以使得我们原本在非延迟的环境下,进入事务后,改为延迟的环境,在进行数据的增删改,从而达到退出事务后,环境依然是而非延迟的环境。总之,在事务中控制延迟约束可以达到在非延迟的环境下,做到延迟的环境下事情,这一切都要归功于事务的强大性能

注:①、延迟约束只能在事务中使用。②提交事务时总会验证表中的数据是否满足约束,不满足时导致事务失败

1、修改t02表的t02_fk约束为非延迟

test=# alter table t02 alter CONSTRAINT t02_fk initially immediate;

2、开启事务,在事务中临时修改t02_fk约束为延迟约束

test=# begin ;        
BEGIN
test=# alter table t02 alter CONSTRAINT t02_fk initially deferred;

3、往子表t02中插入一条数据。执行成功,因为在事务的影响下,我们处在延迟约束的环境下的

test=# insert INTO t02 values (30,'abc'); 

4、往父表t02中插入一条数据

test=# insert INTO t01 values (30,'acac',8);

5、结束事务,自动提交成功

test=# end; 
COMMIT

使用约束时的注意事项

1、一张表只能有一个主键约束,其它非主键列可以结合使用唯一约束+非空约束来实现类似的功能

2、check约束的定义必须是一个条件表达式,表达式要有确定的结果,要么为true,要么为flase

3、我们将列的默认值定义也可以看作是一种定义在表上的约束,用于列的自动填充的缺省值。这句话的意思是,列的默认值其实也是一种约束,这个约束的作用是帮助列自动填充缺省值

4、定义外键约束的列可以与被参照的父表中的列拥有不同的名称,但列的数据类型必须要匹配。就是外键约束,参照表的参照字段与被参照表的被参照字段的数据类型必须要匹配

相关文章:

12-表的约束

知识背景 表的约束&#xff0c;就是在表中的数据上加上约束&#xff0c;也被称为数据完整性约束。数据完整性约束的目的是为了不被规定的、不符合规范的数据进入数据库 在录入数据库或数据发生变化时&#xff0c;DBMS(数据库管理系统)会按照一定的约束条件对数据进行监测&…...

【人工智能】深度学习入门:用TensorFlow实现多层感知器(MLP)模型

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 多层感知器(MLP)是一种基础的神经网络结构,广泛应用于分类和回归任务。作为深度学习的重要组成部分,理解并实现MLP是学习更复杂神经网络模型的基础。本文将介绍多层感知器的核心概念、数学原理,并使用…...

【Go】-go中的锁机制

目录 一、锁的基础知识 1. 互斥量/互斥锁 2. CAS&#xff08;compare and swap&#xff09; 3. 自旋锁 4. 读写锁 5. 乐观锁 & 悲观锁 6. 死锁 二、go中锁机制 1. Mutex-互斥锁 2. RWMutex-读写锁 2.1 RWMutex流程概览 2.2 写锁饥饿问题 2.3. golang的读写锁源…...

c ++零基础可视化——vector

c 零基础可视化——vector 初始化 vector<int> v0(5); // 0 0 0 0 0 vector<int> v1(5, 1); // 1 1 1 1 1 vector<int> v2{1, 2, 3} // 1 2 3 vector<int> v3(v1); // 1 1 1 1 1 vector<vector<int>> v4(2, vect…...

Centos 7 安装 Docker 最新版本

文章目录 一、卸载旧版本二、安装最新版本docker三、问题解决3.1 启动docker报错3.2 启动容器报错 一、卸载旧版本 #如果之前安装过旧版本的Docker&#xff0c;可以使用下面命令卸载 yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest …...

构建高效在线教育:SpringBoot课程管理系统

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理在线课程管理系统的相关信息成为必然。开发…...

二进制与网络安全的关系

二进制与网络安全的关系 声明&#xff01; 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以…...

【计算机网络】网段划分

一、为什么有网段划分 IP地址 网络号(目标网络) 主机号(目标主机) 网络号: 保证相互连接的两个网段具有不同的标识 主机号: 同一网段内&#xff0c;主机之间具有相同的网络号&#xff0c;但是必须有不同的主机号 互联网中的每一台主机&#xff0c;都要隶属于某一个子网 -&…...

VB、VBS、VBA的区别及作用

VB、VBS 和 VBA 是三种与微软 Visual Basic 相关的编程语言或环境&#xff0c;它们在功能和用途上有所不同&#xff1a; # Visual Basic (VB) Visual Basic 是一种面向对象的编程语言&#xff0c;最初由微软公司开发。它是一种高级编程语言&#xff0c;旨在简化开发过程&…...

深度学习中的循环神经网络(RNN)与时间序列预测

一、循环神经网络&#xff08;RNN&#xff09;简介 循环神经网络&#xff08;Recurrent Neural Networks&#xff0c;简称RNN&#xff09;是一种专门用于处理序列数据的神经网络架构。与传统神经网络不同&#xff0c;RNN具有内部记忆能力&#xff0c;能够捕捉数据中的时间依赖…...

Unity 设计模式-原型模式(Prototype Pattern)详解

原型模式 (Prototype Pattern) 原型模式 (Prototype Pattern) 是一种创建型设计模式&#xff0c;它允许通过复制现有的对象来创建新对象&#xff0c;而不是通过直接实例化类。这意味着你可以通过克隆原型对象来生成新的实例&#xff0c;而不必依赖类的构造函数。该模式的核心思…...

如何在 RK3568 Android 11 系统上排查以太网问题

1. 硬件连接检查 在进行软件诊断之前,首先确保所有硬件连接正常: 确认网线可靠插入设备的以太网端口。交换机、路由器中与设备连接的端口是否正常工作。若有可能,尝试更换网线或使用其他端口。2. 使用命令行工具进行基本检查 检查网络接口状态 连接设备并使用 ADB 或终端…...

如何在WPF中嵌入其它程序

在WPF中嵌入其它程序&#xff0c;这里提供两种方案 一、使用WindowsFormHost 使用步骤如下 1、添加WindowsFormsIntegration和System.Windows.Forms引用 2、在界面上放置WindowsFormHost和System.Windows.Forms.Panel 1 <Grid> 2 <WindowsFormsHost> 3…...

大模型呼入系统是什么?

大模型呼入系统是什么&#xff1f; 作者&#xff1a;开源呼叫中心系统 FreeIPCC&#xff0c;Github地址&#xff1a;https://github.com/lihaiya/freeipcc 在呼叫中心领域&#xff0c;大模型呼入是指利用大型语言模型&#xff08;如GPT等&#xff09;处理客户呼入的电话请求&a…...

Flutter:SlideTransition位移动画,Interval动画延迟

配置vsync&#xff0c;需要实现一下with SingleTickerProviderStateMixinclass _MyHomePageState extends State<MyHomePage> with SingleTickerProviderStateMixin{// 定义 AnimationControllerlate AnimationController _controller;overridevoid initState() {super.…...

【Elasticsearch入门到落地】2、正向索引和倒排索引

接上篇《1、初识Elasticsearch》 上一篇我们学习了什么是Elasticsearch&#xff0c;以及Elastic stack(ELK)技术栈介绍。本篇我们来什么是正向索引和倒排索引&#xff0c;这是了解Elasticsearch底层架构的核心。 上一篇我们学习到&#xff0c;Elasticsearch的底层是由Lucene实…...

网络安全概论

一、 网络安全是一个综合性的技术。在Internet这样的环境中&#xff0c;其本身的目的就是为了提供一种开放式的交互环境&#xff0c;但是为了保护一些秘密信息&#xff0c;网络安全成为了在开放网络环境中必要的技术之一。网络安全技术是随着网络技术的进步逐步发展的。 网络安…...

后端开发如何高效使用 Apifox?

对于后端开发者来说&#xff0c;日常工作中少不了接口的设计、调试和文档编写。你是否也曾因接口文档更新不及时、测试工具分散而头疼不已&#xff1f;Apifox&#xff0c;这款全能型工具&#xff0c;或许能成为你的效率神器&#xff01; Apifox究竟有哪些功能能帮助后端开发者…...

实现List接口的三类-ArrayList -Vector -LinkedList

一、ArrayList 数据结构与存储原理 ArrayList是基于动态数组实现的。它在内存中是一块连续的存储空间。当创建一个ArrayList时&#xff0c;会初始化一个默认大小&#xff08;通常为10&#xff09;的数组。随着元素的不断添加&#xff0c;如果数组容量不够&#xff0c;会进行扩…...

LeetCode 904.水果成篮

LeetCode 904.水果成篮 思路&#x1f9d0;&#xff1a; 求水果的最大数目&#xff0c;也就是求最大长度&#xff0c;我们是单调的向前求解&#xff0c;则能够想到使用滑动窗口进行解答&#xff0c;可以用hash表统计每个种类的个数&#xff0c;kinds变量统计当前种类&#xff0c…...

GitHub 开源项目 Puter :云端互联操作系统

每天面对着各种云盘和在线应用&#xff0c;我们常常会遇到这样的困扰。 文件分散在不同平台很难统一管理&#xff0c;付费订阅的软件越来越多&#xff0c;更不用说那些烦人的存储空间限制了。 最近在 GitHub 上发现的一个开源项目 Puter 彻底改变了我的在线办公方式。 让人惊…...

美创科技入选2024数字政府解决方案提供商TOP100!

11月19日&#xff0c;国内专业咨询机构DBC德本咨询发布“2024数字政府解决方案提供商TOP100”榜单。美创科技凭借在政府数据安全领域多年的项目经验、技术优势与创新能力&#xff0c;入选收录。 作为专业数据安全产品与服务提供商&#xff0c;美创科技一直致力于为政府、金融、…...

七天掌握SQL--->第五天:数据库安全与权限管理

1.1 用户权限管理 用户权限管理是指控制用户对数据库的访问和操作权限。在MySQL中&#xff0c;可以使用GRANT和REVOKE命令来管理用户权限。 GRANT命令用于授予用户权限。语法如下&#xff1a; GRANT privileges ON database.table TO userhost IDENTIFIED BY password;其中&…...

数学建模学习(138):基于 Python 的 AdaBoost 分类模型

1. AdaBoost算法简介 AdaBoost(Adaptive Boosting)是一种经典的集成学习算法,由Yoav Freund和Robert Schapire提出。它通过迭代训练一系列的弱分类器,并将这些弱分类器组合成一个强分类器。算法的核心思想是:对于被错误分类的样本,在下一轮训练中增加其权重;对于正确分类…...

丹摩|丹摩智算平台深度评测

1. 丹摩智算平台介绍 随着人工智能和大数据技术的快速发展&#xff0c;越来越多的智能计算平台涌现&#xff0c;为科研工作者和开发者提供高性能计算资源。丹摩智算平台作为其中的一员&#xff0c;定位于智能计算服务的提供者&#xff0c;支持从数据处理到模型训练的全流程操作…...

『VUE』34. 异步组件(详细图文注释)

目录 加载速度的优化示例代码总结 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 加载速度的优化 实际项目中你可能会有几十个组件,如果一开始就加载了全部组件(哪怕其中有些组件你暂时用不到)这无疑大大增加了响应时间,用户体验…...

深入解析自校正控制(STC)算法及python实现

目录 深入解析自校正控制(STC)算法第一部分:自校正控制算法概述1.1 什么是自校正控制1.2 自校正控制的核心思想1.3 STC 的应用场景1.4 STC 的分类第二部分:自校正控制算法的数学基础2.1 动态系统模型2.2 参数辨识方法2.3 控制器设计2.4 稳定性分析第三部分:Python 实现自校…...

《macOS 开发环境配置与应用开发》

一、引言 macOS 作为一款强大而流行的操作系统&#xff0c;为开发者提供了丰富的开发机会和优秀的开发环境。无论是开发原生的 macOS 应用&#xff0c;还是进行跨平台开发&#xff0c;了解和掌握 macOS 开发环境的配置以及应用开发的方法至关重要。本文将详细介绍 macOS 开发环…...

WebSocket 常见问题及解决方案

什么是 WebSocket&#xff1f; WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。它允许客户端和服务器之间进行双向通信&#xff0c;而不需要像传统 HTTP 那样每次请求都需要建立新的连接。WebSocket 协议在 2011 年被 IETF 定义为 RFC 6455 标准。 特点 双向通信&…...

如何在 .gitignore 中仅保留特定文件:以忽略文件夹中的所有文件为例

在日常的开发工作中&#xff0c;使用 Git 来管理项目是不可或缺的一部分。项目中的某些文件夹可能包含大量的临时文件、生成文件或不需要版本控制的文件。在这种情况下&#xff0c;我们通常会使用 .gitignore 文件来忽略这些文件夹。然而&#xff0c;有时我们可能希望在忽略整个…...