MySQL数据库(数据库约束)

目录

数据库约束

数据库约束的类型: 

null约束 : 

unique约束(唯一约束): 

default约束(默认值约束):  

primary key约束(主键约束): 

foreign key约束(外键约束): 


数据库约束

数据库约束的类型: 

not null- 指示某列不能存储 null值。
unique- 保证某列的每行必须有唯一的值。
default - 规定没有给列赋值时的默认值。
primary key - not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标
识,有助于更容易更快速地找到表中的一个特定的记录。
foreign key - 保证一个表中的数据匹配另一个表中的值的参照完整性

null约束 : 

创建表时,可以指定某列不为空

 drop table if exists student;
 create table student (id int not null,sn int,name varchar(20),qq_mail varchar(20));

unique约束(唯一约束): 

指定sn列为唯一的、不重复的:

 drop table if exists student;
 create table student (id int,sn int unique,name varchar(20),qq_mail varchar(20));

 default约束(默认值约束):  

指定插入数据时,name列为空,默认值无名氏:

 drop table if exists student;
 create table student (id int,sn int ,name varchar(20) default '无名氏',qq_mail varchar(20));

primary key约束(主键约束): 

指定id列为主键:

drop table if exists student;
create table student (id int primary key,sn int ,name varchar(20),qq_mail varchar(20));


对于整数类型的主键,常配搭自增长auto_increment来使用。插入数据对应字段不给值时,使用最大值+1。

drop table if exists student;
create table student (id int primary key auto_increment,sn int ,name varchar(20),qq_mail varchar(20));
desc student;
insert into student values(1,1,'张三','********@qq.com');
insert into student (sn,name,qq_mail)values(2,'李四','********@qq.com');
select *from student;

foreign key约束(外键约束): 

外键用于关联其他表的主键或唯一键,语法:
语法形式:

foreign key(字段名) references 主表(列)
create table class (id int primary key,name varchar(20));
 create table student(id int primary key,name varchar(20),class_id int,foreign key(class_id)references class(id));

这样就使得student和class产生了联系。而且在插入数据的时候,只能插入符合外键约束的数据:

insert into class values(1,'java1班');
insert into class values(2,'java2班');
select *from class;

class中的数据: 

 insert into student values(1,'张三',2);
 insert into student values(2,'李四',1);
 select *from student;

student中的数据:

也就是说张三class_id为2,也就是java1班,李四就是java2班的。这是我们插入一条在class中不存在的id:

 insert into student values (3,'王五',100);

就会出现报错了,无法插入,这就体现了外键的约束。

还要注意的一点就是,外键约束约束的其实是双方,(我们可以把class看成主(父)表,student看成子表) ,除了上述关系外,如果我们想删除父表,也必须删除子表,否则无法删除:

drop table class;

 因为约束的存在所以无法删除。要想删除就要先把子表删除。

猜你喜欢

转载自blog.csdn.net/m0_67995737/article/details/127807353