数据库7大约束

news2025/1/10 2:56:50

4 约束

数据类型

什么是数据:数字、小说、图片、音乐、视频

针对不同的数据展现形式,我们对数据进行了分类,数据类型。

  • 数字类型:存放数字的,int
  • 浮点型类型:存放数字,float,小数
  • 字符串类型:存放一切字符varchar
  • 二进制类型:存放特殊数据
  • 日期类型:只能存放日期类型
4.1 定义

约束是在符合数据类型的情况下,对数据的限制。

主键约束:empno(int):1,2,3,4,1,2,3,4

4.2 分类

有七个,但是oracle严格意义上有七个,mysql严格意义上只有六个,但是我们通过一种手段让其实现七个。

  • 非空约束:对一个列有要求,要求其不能为空值。
  • 唯一约束:对一个列有要求,要求其值不能跟其他已经存在的值相同(注册邮箱,注册用户,手机号)
  • 主键约束:当一列需要有非空约束,也需要有唯一约束的时候,我们直接使用主键约束就会同时满足非空和唯一(一个表的第一列)
  • 默认值约束:对一个表的列设置一个值,如果在给表添加数据的时候,这个列你没有给值,就用设置的这个默认值
  • 检查约束:对一个表的类的取值有规定:只能为什么或者什么(性别)
  • 自增长:对一个表的列的值,自动在列历史最大值的基础上增加1(一般跟主键一起使用)
  • 外键约束:一个表的取值,需要参考另外一个表的列的取值
4.3 非空约束

image-20211206120831430

4.3.1 创建非空约束
-- 添加非空约束
-- 1)创建表的时候直接添加非空约束
-- create table tbname(...列 数据类型 not null,...);

-- 案例:创建一个班级表myclass(cid,cname,loc),其中cid添加非空约束
create table myclass(cid int not null,cname varchar(20),loc varchar(20))

-- 验证非空约束是否生效
select * from myclass;
insert into myclass(cid, cname, loc) values(1001, '测试班', '教室二');
insert into myclass(cname, cid, loc) values('测试班', 1001, '教室二');
insert into myclass values(1001, '测试班', '教室二');

insert into myclass(cname, loc) values('开发班', '教室三'); -- [Err] 1364 - Field 'cid' doesn't have a default value
insert into myclass(cid, cname, loc) values(null, '开发班', '教室三'); -- [Err] 1048 - Column 'cid' cannot be null

-- 练习:创建学生表mystuden(sid,sname,cid),其中sid添加非空约束


-- 2)创建表的时候没有添加,创建完表,又想添加
-- ALTER table tbname change old_列 new_列 数据类型 not null;


-- 准备工作:
drop table if EXISTS myclass;  -- 如果存在这个表就删除这个表

-- 案例:创建一个班级表myclass(cid,cname,loc),没有非空约束
create table myclass(cid int,cname varchar(20),loc varchar(20));

-- 给表中的cid列添加非空约束
ALTER table myclass change cid cid int not null;  -- alter修改表

-- 验证非空约束
insert into myclass values(1001, '测试班', '教室二'); -- 添加一条正常数据,证明表是ok
insert into myclass(cname, loc) values('开发班', '教室三'); -- [Err] 1364 - Field 'cid' doesn't have a default value
insert into myclass(cid, cname, loc) values(null, '开发班', '教室三') -- [Err] 1048 - Column 'cid' cannot be null

4.3.2 删除非空约束
-- 删除非空约束
-- alter table tbname change old_列 new_列 数据类型  null;

-- 案例:删除myclass中的cid上的非空约束
alter table myclass change cid cid int  null;


-- 验证约束是否删除成功
insert into myclass(cname, loc) values('开发班', '教室三'); -- 应该成功
insert into myclass(cid, cname, loc) values(null, '测试班', '教室4')  -- 应该成功
select * from myclass;

-- 练习:针对mystudent表(sid,sname, cid),先创建表,然后添加sid的非空约束,然后删除约束并给出响应的验证

4.4 唯一性约束

image-20211206121128728

4.4.1 创建唯一约束
# 2.唯一约束
# 作用:确保一张表中的一个列的取值没有重复的,确保唯一性
# 场景:一般用户名、手机号
# 1)添加唯一约束
-- 创建表的同时添加唯一约束
-- create table tbname (...,列名 数据类型  unique,...);  如果添加的时候没有给约束设置名字默认约束名为列名

-- 准备工作:
drop table if EXISTS myclass;

-- 案例:创建表myclass(cid,cname,loc),其中cid添加唯一约束
create table myclass(
		cid int unique, 
		cname varchar(20), 
		loc varchar(20)
);

-- 验证唯一约束是否成功
insert into myclass values(1001,'测试班','教室二');
insert into myclass values(1001,'开发班','教室3'); -- 不应该成功:[Err] 1062 - Duplicate entry '1001' for key 'cid'  重复给cid键输入1001
select * from myclass;


-- 2)创建表的时候没有添加唯一约束,创建表之后,再添加唯一约束
-- alter table tbname add [CONSTRAINT uk_列名] unique(列);   # 中括号内的参数可以写也可以不写

-- 准备工作:
drop table if EXISTS myclass;
-- 案例:创建表myclass(cid,cname,loc),创建完后,给cid列添加唯一约束
-- 创建表(没有唯一约束的):
create table myclass(
		cid int, 
		cname varchar(20), 
		loc varchar(20)
);
-- 添加cid的唯一约束:
alter table myclass add unique(cid); -- 没有使用[CONSTRAINT uk_列名],唯一约束的名字就默认是列名,如果使用了,就使用自定义的唯一约束名字

-- 验证唯一约束是否成功
insert into myclass values(1001,'测试班','教室二');
insert into myclass values(1001,'开发班','教室3'); -- 不应该成功:[Err] 1062 - Duplicate entry '1001' for key 'cid'  重复给cid键输入1001
select * from myclass;

-- ****************************** 给约束添加名字 ************************
-- 验证添加语法
-- 创建表的时候没有添加唯一约束,创建表之后,再添加唯一约束
-- alter table tbname add [CONSTRAINT uk_列名] unique(列);   # 中括号内的参数可以写也可以不写

-- 准备工作:
drop table if EXISTS myclass;
-- 创建表(没有唯一约束的):
create table myclass(
		cid int, 
		cname varchar(20), 
		loc varchar(20)
);
-- 添加约束:alter table tbname add [CONSTRAINT 约束名字] unique(列);   # 中括号内的参数可以写也可以不写
alter table myclass add CONSTRAINT hahahahah unique(cid);

-- 验证唯一约束是否添加成功:
insert into myclass values(1001,'测试班','教室二');  
insert into myclass values(1001,'开发班','教室3'); -- 不成功:[Err] 1062 - Duplicate entry '1001' for key 'hahahahah'
select * from myclass;

-- 针对mystuent(sid,sname,cid),练习唯一约束
4.4.2 删除唯一约束
-- 删除唯一约束
-- alter table tbname drop index 唯一约束的名字
alter table myclass drop index cid;


-- 验证:重新执行插入语句1001,可以出入成功
insert into myclass values(1001,'开发班','教室3');  -- 可以执行成功
4.5 主键约束
4.5.1创建主键约束
# 3.主键约束
# 作用:确保表中的某列的值是唯一且不为空
# 场景:一张表的第一列(习惯)所有跟编号相关都是主键

-- 1)创建表的时候添加主键约束--中间添加
-- create table tbname (列1 数据类型 PRIMARY key, 列2 数据类型..);

-- 案例:针对myclass(cid,cname,loc)创建表的同时,添加cid为主键
-- 准备工作:
drop table if EXISTS myclass;
-- 创建表:
create table myclass(
	cid int primary key,
	cname VARCHAR(20),
	loc VARCHAR(20)
);

-- 验证(既然主键的特性非空且唯一):
insert into myclass(cid, cname, loc) VALUES(1001,'测试班','教室2');  -- cid=1001,第一次插入可以成功
insert into myclass(cid, cname, loc) VALUES(1001,'开发班','教室3');  -- cid=1001,第二次插入失败:[Err] 1062 - Duplicate entry '1001' for key 'PRIMARY
insert into myclass(cid, cname, loc) VALUES(null,'开发班','教室3');  -- cid=null,失败:[Err] 1048 - Column 'cid' cannot be null


-- 2)创建表的同时添加主键约束--最后添加
-- create table tbname (列1 数据类型 , 列2 数据类型.., PRIMARY key(列1));

-- 案例:针对myclass(cid,cname,loc)创建表的同时,添加cid为主键
-- 准备工作:
drop table if EXISTS myclass;
-- 创建表:
create table myclass(
	cid int,
	cname VARCHAR(20),
	loc VARCHAR(20),
	primary key(cid)
);

-- 验证(既然主键的特性非空且唯一):
insert into myclass(cid, cname, loc) VALUES(1001,'测试班','教室2');  -- cid=1001,第一次插入可以成功
insert into myclass(cid, cname, loc) VALUES(1001,'开发班','教室3');  -- cid=1001,第二次插入失败:[Err] 1062 - Duplicate entry '1001' for key 'PRIMARY
insert into myclass(cid, cname, loc) VALUES(null,'开发班','教室3');  -- cid=null,失败:[Err] 1048 - Column 'cid' cannot be null


-- 3)创建表没有添加主键约束,创建完了才添加主键约束
-- alter table tbname add [CONSTRAINT 主键的名字] PRIMARY key(列);   # pk_列名

-- 案例:针对myclass(cid,cname,loc)创建表的同时,添加cid为主键
-- 准备工作:
drop table if EXISTS myclass;
-- 创建表(不添加约束):
create table myclass(
	cid int,
	cname VARCHAR(20),
	loc VARCHAR(20)
);

-- 添加约束
alter table myclass add constraint pk_cid PRIMARY key(cid);

-- 验证:
insert into myclass(cid, cname, loc) VALUES(1001,'测试班','教室2');  -- cid=1001,第一次插入可以成功
insert into myclass(cid, cname, loc) VALUES(1001,'开发班','教室3');  -- cid=1001,第二次插入失败:[Err] 1062 - Duplicate entry '1001' for key 'PRIMARY
insert into myclass(cid, cname, loc) VALUES(null,'开发班','教室3');  -- cid=null,失败:[Err] 1048 - Column 'cid' cannot be null

4.5.2 删除主键约束
-- 4)删除主键约束
-- alter table tbname drop PRIMARY key;

-- 案例:删除myclass的主键约束
alter table myclass drop primary key;

-- 验证:
select * from myclass;  -- 此时有一条数据
insert into myclass(cid, cname, loc) VALUES(1001,'开发班','教室3'); -- 成功
insert into myclass(cid, cname, loc) VALUES(null,'开发班','教室3'); -- 失败,因为添加主键的时候,该列会同时满足唯一和非空,但是删除的时候只会删除唯一
alter table myclass change cid cid int null; -- 上面插入失败原因是因为非空约束,此时如果要插入成功需要去除非空约束
4.6 默认值约束

image-20211206152726549

4.6.1 创建默认值约束
# 4.默认值约束
# 作用:给一个表中的某列设置一个初始值
# 场景:昵称(未知)、性别(男)一般都有默认值

-- 创建默认值约束
-- 1)创建表的时候添加默认值约束
-- create table tbname (...,列 数据类型 default 默认值,...);

-- 案例:针对myclass添加loc的默认值为:金融港六层
-- 数据准备
drop table if EXISTS myclass;
-- 创建表
create table myclass(
	cid int,
	cname VARCHAR(20),
	loc VARCHAR(20) default '金融港六层'
);

-- 验证(如果不给loc设置值,则默认使用金融港六层):
insert into myclass (cid,cname,loc) values(1001,'测试班','教室2'); -- 插入成功,loc='教室2'
select * from myclass;
insert into myclass(cid, cname) values(1002,'开发班'); -- 插入成功,但是loc的值没有给,所以会使用默认值:金融港六层


-- 2)创建完表,再添加默认值约束
-- alter table tbname change old_列 new_列 数据类型 default 默认值;

-- 案例:针对myclass先创建表,然后添加loc的默认值为:金融港六层
-- 数据准备
drop table if EXISTS myclass;
-- 创建表
create table myclass(
	cid int,
	cname VARCHAR(20),
	loc VARCHAR(20)
);

-- 添加约束:
alter table myclass change loc loc VARCHAR(20) default '金融港六层';

-- 验证:
insert into myclass (cid,cname,loc) values(1001,'测试班','教室2'); -- 插入成功,loc='教室2'
select * from myclass;
insert into myclass(cid, cname) values(1002,'开发班'); -- 插入成功,但是loc的值没有给,所以会使用默认值:金融港六层

4.6.2 删除默认值约束
-- 3)删除默认值约束
-- alter table tbname change old_列 new_列 数据类型 default null;

-- 案例:删除myclass表loc的默认值约束
alter table myclass change loc loc varchar(20) default null; -- 默认值约束:null


-- 练习:在mystudent上添加默认值约束和删除默认值约束并验证

4.7 检查约束
4.7.1 创建检查约束
# ******检查约束 check()--mysql不支持
# 作用:控制表中的某个列的取值范围
# 场景:性别

-- 创建检查约束
-- 1)创建表的同时添加检查约束
-- create table tbname(...,列 set(a,b,c),....);

-- 案例:针对mystudent(sid,sname,ssex,cid),其中ssex有检查约束
-- 数据准备:
-- 创建表:
create table mystudent(
	sid int,
	sname varchar(20),
	ssex set('男','女'),  -- set:集合   (1,2,3,4,'yyyy','ppppp')  
	cid int
);

-- 验证:
insert into mystudent(sid,sname,ssex,cid) values(101,'丁淳','男',1001); -- 插入成功,因为ssex='男'符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(102,'小红','女',1001); -- 插入成功,因为ssex='女'符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(103,'小中','中',1001); -- 插入失败,因为ssex='中'不符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(103,'小中',1,1001); -- 不可取这种方式,虽然1,2,3的值可以实现一定的效果
select * from mystudent;


-- 2)创建完表,添加检查约束
-- alter table tbname change old_列 new_列 set('男','女');

-- 案例:针对mystudent(sid,sname,ssex,cid),创建完表之后,再给ssex添加检查约束
-- 数据准备:
drop table if EXISTS mystudent;
-- 创建表:
create table mystudent(
	sid int,
	sname varchar(20),
	ssex  varchar(20), 
	cid int
);

-- 添加约束
alter TABLE mystudent change ssex ssex set('男','女');

-- 验证:
insert into mystudent(sid,sname,ssex,cid) values(101,'丁淳','男',1001); -- 插入成功,因为ssex='男'符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(102,'小红','女',1001); -- 插入成功,因为ssex='女'符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(103,'小中','中',1001); -- 插入失败,因为ssex='中'不符合检查约束
insert into mystudent(sid,sname,ssex,cid) values(103,'小中',1,1001); -- 不可取这种方式,虽然1,2,3的值可以实现一定的效果
select * from mystudent;
4.7.2 删除检查约束
-- 3)删除检查约束
-- alter talbe tbname change old_列 new_列 数据类型;

-- 案例:删除mystudent中的ssex上的检查约束
ALTER table mystudent change ssex ssex varchar(20);

-- 验证:
insert into mystudent(sid,sname,ssex,cid) values(104,'小中','天大地大',1001); -- 插入成功
select * from mystudent;
4.9 自增长
4.9.1 创建自增长约束
# **********自增长
# 作用:一般跟主键一起使用,保证某个列的值自动递增
# 场景:淘宝订单(订单编号)

-- 创建自增长约束
-- 1)建表时添加自增长约束
-- create table tbname(...,列 数据类型 auto_increment primary key,....);

-- 案例:给myclass表中cid添加自增和主键

-- 准备数据:
drop table if EXISTS myclass;
-- 创建表
create table myclass(
	cid int primary key auto_increment,
  cname varchar(20),
  loc varchar(20)
);

-- 验证:
insert into myclass(cname,loc) values('test','武汉'); -- 插入成功,一张表中的第一条数据,其中cid没有给值,从1开始
-- 构造数据:
insert into myclass(cname,loc) values('test2','武汉');
insert into myclass(cname,loc) values('test3','武汉');
insert into myclass(cname,loc) values('test4','武汉');
insert into myclass(cname,loc) values('test5','武汉');
insert into myclass(cname,loc) values('test6','武汉');
insert into myclass(cname,loc) values('test7','武汉');
insert into myclass(cname,loc) values('test8','武汉');
insert into myclass(cname,loc) values('test9','武汉');
insert into myclass(cname,loc) values('test10','武汉');
insert into myclass(cname,loc) values('test11','武汉'); -- cid自动增长11
-- 删除10和11
delete from myclass where cid in(10,11);
-- 重新插入一条数据,cid的值应该为12
insert into myclass(cname,loc) values('test12','武汉'); -- cid自动为12
select * from myclass;


-- 2)建完表后添加自增长约束
-- ALTER table tbname change olc_列 new_列 数据类型 auto_increment;

-- 案例:创建myclass表,然后再给cid添加自增

-- 准备数据:
drop table if EXISTS myclass;
-- 创建表
create table myclass(
	cid int primary key,
  cname varchar(20),
  loc varchar(20)
);

-- 添加cid的自增长约束
alter table myclass change cid cid int auto_increment;

-- 验证:
insert into myclass(cname,loc) values('test','武汉'); -- 插入成功,一张表中的第一条数据,其中cid没有给值,从1开始
-- 构造数据:
insert into myclass(cname,loc) values('test2','武汉');
insert into myclass(cname,loc) values('test3','武汉');
insert into myclass(cname,loc) values('test4','武汉');
insert into myclass(cname,loc) values('test5','武汉');
insert into myclass(cname,loc) values('test6','武汉');
insert into myclass(cname,loc) values('test7','武汉');
insert into myclass(cname,loc) values('test8','武汉');
insert into myclass(cname,loc) values('test9','武汉');
insert into myclass(cname,loc) values('test10','武汉');
insert into myclass(cname,loc) values('test11','武汉'); -- cid自动增长11
-- 删除10和11
delete from myclass where cid in(10,11);
-- 重新插入一条数据,cid的值应该为12
insert into myclass(cname,loc) values('test12','武汉'); -- cid自动为12
select * from myclass;


-- 再次插入一条数据,该数据cid给值:99
insert into myclass(cid,cname,loc) values(99,'test12','武汉'); -- cid插入的值为99,所以最后cid是99
-- 再次插入一条数据,不给cid的值,那么cid的值为:100
insert into myclass(cname,loc) values('test100','武汉'); 
select * from myclass;
4.9.2 删除自增长约束
-- 3)删除自增长约束
-- ALTER table tbname change olc_列 new_列 数据类型 ;

-- 案例:删除mycalss的自增长约束
alter table myclass change cid cid int;

-- 验证:
insert into myclass(cname,loc) values('test101','武汉');  -- 插入失败,因为cid没有给值,cid的值默认是null,主键不允许:[Err] 1364 - Field 'cid' doesn't have a default value


-- 练习:在mystudent表中验证自增张的添加和删除
4.10 外键约束

A表中的某个列的取值需要参考B表中的主键

子表/从表中的某个列(外键)的取值需要参考主表中的主键

现在开发们已经不建议添加过多的外键(软件的业务复杂度)

image-20211206172028760

4.10.1创建外键约束
# **** 外键约束
# 作用:约束一张表中的某个列的值的取值范围需要参考另外一张表的主键,防止冗余的垃圾数据
# 场景:淘宝登陆,用户名(user表 user_id),下订单(订单表order_id 主键     user_id)

-- 添加外键
-- 1)创建表的时候添加外键
-- create table 子表 (列1 数据类型,列2 数据类型,...,constraint 外键的约束名 foreign key (外键的列) REFERENCES 主表(主键)


-- 案例:给mystudent中的cid列添加外键约束(参考值为myclass表中的主键cid)

-- 数据准备:
drop table if EXISTS myclass ;
drop table if EXISTS mystudent ;
create table myclass(
	cid int PRIMARY key,
	cname VARCHAR(20),
	loc varchar(20)
);

-- 创建表+外键约束:
create table mystudent(
	sid int,
	sname VARCHAR(20),
	aaa int,
	constraint fk_aaa foreign key(aaa) REFERENCES myclass(cid)
);

-- 验证:
-- 给主表myclass添加数据
insert into myclass values(31,'test31','wuhan');
insert into myclass values(32,'test32','wuhan');
insert into myclass values(33,'test33','wuhan');
select * from myclass;
-- 给子表mystudent添加数据
insert into mystudent(sid,sname,aaa) values(101,'小明',31);  -- 插入成功
insert into mystudent(sid,sname,aaa) values(102,'小红',null);  -- 插入成功:外键并没有说不允许为空
insert into mystudent(sid,sname,aaa) values(103,'小黄',55);  -- 插入失败:[Err] 1452 - Cannot add or update a child row: a foreign key constraint fails (`部门数据库`.`mystudent`, CONSTRAINT `fk_aaa` FOREIGN KEY (`aaa`) REFERENCES `myclass` (`cid`))


-- 2)创建完表,再添加外键
-- ALTER TABLE 从表 ADD CONSTRAINT fk_1 FOREIGN KEY (外键列) REFERENCES 主表(主键列)

-- 案例:创建mystudent表后,再给mystudent中的cid列添加外键约束(参考值为myclass表中的主键cid)

-- 数据准备:
drop table if EXISTS mystudent ;
drop table if EXISTS myclass ;
create table myclass(
	cid int PRIMARY key,
	cname VARCHAR(20),
	loc varchar(20)
);

create table mystudent(
  sid int,
	sname VARCHAR(20),
	cid int
);

-- 添加外键约束:
alter table mystudent add  foreign key(cid) references myclass(cid);  -- 没有给外键起名字

-- 验证:
-- 给主表myclass添加数据
insert into myclass values(31,'test31','wuhan');
insert into myclass values(32,'test32','wuhan');
insert into myclass values(33,'test33','wuhan');
select * from myclass;
-- 给子表mystudent添加数据
insert into mystudent(sid,sname,cid) values(101,'小明',31);  -- 插入成功
insert into mystudent(sid,sname,cid) values(102,'小红',null);  -- 插入成功:外键并没有说不允许为空
insert into mystudent(sid,sname,cid) values(103,'小黄',55);  -- 插入失败:[Err] 1452 - Cannot add or update a child row: a foreign key constraint fails (`部门数据库`.`mystudent`, CONSTRAINT `fk_aaa` FOREIGN KEY (`aaa`) REFERENCES `myclass` (`cid`))

4.10.2 删除外键
-- 3)删除外键
-- alter table tbname drop foreign key fkname;  -- 外键的名字

-- 查看外键名
show create table mystudent; -- 结果如下
-- CREATE TABLE `mystudent` (
--   `sid` int(11) DEFAULT NULL,
--   `sname` varchar(20) DEFAULT NULL,
--   `cid` int(11) DEFAULT NULL,
--   KEY `yyyyy` (`cid`),
--   CONSTRAINT `yyyyy` FOREIGN KEY (`cid`) REFERENCES `myclass` (`cid`)
-- ) ENGINE=InnoDB DEFAULT CHARSET=utf8

-- 案例:删除mystudent表中的外键
-- 删除外键:
alter table mystudent drop foreign key yyyyy;

-- 验证:
insert into mystudent(sid,sname,cid) values(103,'小黄',55);   -- 插入成功
select * from mystudent;




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

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

相关文章

大数据关联规则算法

关联性(Association) 定义:指一个变量能够提供有关另一个变量的信息。特点:关联性是一个广泛的概念,它可以包括直接的、间接的、强的或弱的联系。 相关性(Correlation) 定义:指两个…

低版本火狐浏览器报错:class is a reserved identifier

低版本火狐浏览器报错:class is a reserved identifier 原因:react-dnd,dnd-core 等node包的相关依赖有过更新,使得在低版本火狐浏览器中不支持 class 解决方法:在使用webpack打包构建时,编译排除node_modu…

SonarQube集成Jenkins平台搭建

SonarQube平台搭建 一、项目搭建的必要条件 SonarQube 8.9.10 previous LTS 依据公司现有服务目前的Jdk版本1.8,需要选择一个适用的长期支持版本,我在这里选用的是SonarQube 8.9.10 previous LTS。下载地址:Download Previous SonarQube Ver…

2000-2022年全国平均气温数据,多年份,多字段可查询,可预览数据

基本信息. 数据名称: 全国平均气温数据 数据格式: Shp、Excel 数据时间: 2000-2022年 数据几何类型: 面 数据坐标系: WGS84坐标系 数据来源:网络公开数据 数据字段: 序号字段名称字段说明1xzqhdm行政区划代码2xzqhmc行政区划名称3qw2001m01…

E36150系列 自动量程台式电源

E36150系列 自动量程台式电源 <<<KEYSIGHT是德科技>>> “ Keysight E36150 系列自动量程台式直流电源包含两个型号&#xff0c;其单通道输出功率可达 800 W。 E36150 系列可输出高达 60 V 的电压和 80 A 的电流&#xff0c;其可用功率足以满足您的测试需…

MySQL之优化服务器设置(四)

优化服务器设置 InnoDB的IO配置 双写缓冲(Doublewrite Buffer) InnoDB用双写缓冲来避免页没写完整所导致的数据损坏。当一个磁盘写操作不能完整地完成时&#xff0c;不完整的页写入就可能发生&#xff0c;16KB的页可能只有一部分被写到磁盘上。有多种多样的原因(崩溃、Bug&am…

阿里云PAI大模型评测最佳实践

作者&#xff1a;施晨、之用、南茵、求伯、一耘、临在 背景信息 内容简介 在大模型时代&#xff0c;随着模型效果的显著提升&#xff0c;模型评测的重要性日益凸显。科学、高效的模型评测&#xff0c;不仅能帮助开发者有效地衡量和对比不同模型的性能&#xff0c;更能指导他…

OS复习笔记ch11-3

接下来&#xff0c;我们简单地回顾一下I/O缓冲&#xff08;之前在ch5-4-1的时候有提到过&#xff09; I/O缓冲 背景&#xff1a; 假设进程I/O需要在灰色区间读写&#xff0c;而灰色区间由于阻塞而被对换出去了&#xff0c;此时OS找不到对应的内存地址&#xff0c;这样就容易发…

Shell脚本、相关命令;重定向、管道符、变量相关命令讲解

目录 Shell脚本 概念 执行命令流程的交互区别 交互式 非交互式 Shell脚本应用场景 Shell的作用 Shell的作用 —— 命令解释器&#xff0c;“翻译官” 列出系统中全部解释器 实验 脚本的基本书写格式和执行命令 在子bash下执行脚本 指定解释器的方式执行脚本 指定…

nodejs的await和async

例子 const fs require(fs).promises;async function getFileContent(filePath) {const content await fs.readFile(filePath, utf8); console.log(content); // 这行会在文件读取完成后执行 }getFileContent(example.txt); console.log(123); // 这行会立即执行输出结果&…

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/023dbdeb215b4b4580f7f54706e32af9.pn当使用unsloth做微调时&#xff0c;发现找不到libcuda&#xff0c;很自然想到需要软链接到最新…

2024最新AI大模型-LLm八股合集(八)-Transformer模型

更多2024最新AI大模型-LLm八股合集可以拉到文末&#xff01;&#xff01;&#xff01; MHA & MQA & MGA &#xff08;1&#xff09;MHA 从多头注意力的结构图中&#xff0c;貌似这个所谓的多个头就是指多组线性变换层&#xff0c;其实并不是&#xff0c;只有使用了一…

PS去除logo背景

一、打开图片 二、点击通道选择色差最明显的通道 三、复制通道 四、点击载入 五、反选ctrlshifti&#xff08;鼠标右键亦可&#xff0c;然后调整下范围&#xff09; 六、点击图层&#xff0c;复制图层&#xff08;ctrlJ&#xff09; &#xff08;先确保图层是解锁的&#xff0…

二叉树-输出二叉树的右视图

目录 一、问题描述 二、解题思路 三、代码实现 四、刷题链接 一、问题描述 二、解题思路 这里右视图类似于立方体的右视图&#xff0c;从右边看每一层第一个看到的结点的集合就是需要返回的结果&#xff0c;注意返回的结点是有相对顺序的&#xff0c;比如上面的1,3,5对应第…

[WTL/Win32]_[中级]_[MVP架构在实际项目中的应用]

场景 在开发Windows和macOS的界面软件时&#xff0c;Windows用的是WTL/Win32技术&#xff0c;而macOS用的是Cocoa技术。而两种技术的本地语言一个主打是C,另一个却是Object-c。界面软件的源码随着项目功能增多而增多&#xff0c;这就会给同步Windows和macOS的功能造成很大负担…

APM Profile 在系统可观测体系中的应用

引言 应用程序性能分析&#xff08;Application Performance Management&#xff0c;APM&#xff09;是一个广泛的概念&#xff0c;涉及应用程序运行时各种性能指标的监测、诊断和优化。在可观测体系建设中&#xff0c;APM 是保障系统业务运行性能的关键技术&#xff0c;确保用…

堆优化版Dijkstra求最短路-java

主要通过堆优化Dijkstra算法解决最短路&#xff0c;可以跟朴素版的Dijkstra算法进行对比。 文章目录 前言 一、Dijkstra求最短路 二、算法思路 1.邻接表存储图 2.用小根堆优化Dijkstra 三、代码如下 1.代码如下&#xff08;示例&#xff09;&#xff1a; 2.读入数据 3.代码运行…

OpenGL绘制Bezier曲面

Bezier的定义 贝塞尔曲面是贝塞尔曲线在二维上的扩展。它由一组控制点定义,通过这些控制点生成光滑的曲面。贝塞尔曲面通常用两个参数 u u u和 v v v来表示,这两个参数的取值范围都在 [0, 1] 之间。 数学表示 P ( u , v ) = ∑ i = 0 n ∑ j = 0 m p i j ⋅ B i , n ( u ) ⋅…

基于ysoserial的深度利用研究(命令回显与内存马)

0x01 前言 很多小伙伴做反序列化漏洞的研究都是以命令执行为目标&#xff0c;本地测试最喜欢的就是弹计算器&#xff0c;但没有对反序列化漏洞进行深入研究&#xff0c;例如如何回显命令执行的结果&#xff0c;如何加载内存马。 遇到了一个实际环境中的反序列化漏洞&#xff…

text2vec 如何选择 chunksize 和 splitter?

0x00 导读 对 text2vec 来说&#xff0c;chunksize 选多大合适&#xff1f; 应该选择哪种 splitter &#xff1f; BCE 还是 BGE &#xff1f; 面对这些 RAG 问题&#xff0c;本文根据 text2vec 模型原理做假设&#xff0c;并用 HuixiangDou 真实数据验证&#xff0c;最终给出…