MySQL约束超详解

目录
  • mysql约束操作
    • 1.非空约束
    • 2.唯一约束
    • 3.主键约束
    • 4.外键约束
    • 5、级联

mysql约束操作

概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。

分类:

  • 主键:primary key
  • 非空约束:not null
  • 唯一约束:unique
  • 外键约束:foreign key

1.非空约束

not null,值不能为空。

创建表时添加非空约束:

create table stu(
 id int,
 name varchar(20) not null
);

创建表完后,添加非空约束

alter table stu 
modify name varchar(20) not null;

删除非空约束

alter table stu 
modify name varchar(20);

2.唯一约束

unique,值不能重复。

创建表时添加唯一约束

create stu(
 id int;
 phone_number varchar(20) unique
);

注意:mysql中,唯一约束限定的列的值可以有多个null

删除唯一约束

alter table stu
drop index phone_number;

创建表完后,添加唯一约束

alter table stu 
modify phone_number varchar(20) unique;

3.主键约束

primary key,

  • 非空且唯一。
  • 一张表只能有一个字段为主键。
  • 主键就是表中记录的唯一标识。

创建表时添加主键约束

create table stu( 
 id int primary key,
 name varchar(20)
);

删除主键

alter table stu 
drop primary key;

创建表完后,添加主键

alter table stu 
modify id int primary key ;

这里补充一个知识点:自动增长

概念:如果某一列是数值类型的,使用auto_increment可以来完成自动增长。

例子:

在创建表时,添加主键约束,并且完成主键自动增长

create table stu(
 id int primary key auto_increment,
 name varchar(20)
);
#自动增长会根据当前列的最后一行的值往后增加。

删除自动增长

alter table stu
modify id int;
#这样只会删除自动增长,主键删不掉。

创建表完后,在添加自动增长

alter table stu
modify id int auto_increment;

4.外键约束

foreign ley,让表与表产生关系,从而保证数据的正确性。

在创建表时,可以添加外键

create table 表名(
 ...
 外键列
 constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)
);

删除外键

alter table 表名 drop foreign key 外键名称;

创建表之后,添加外键

alter table 表名 add constraint 外键名称 foreign key (外键字段名称) references 主表名称(主表列名称);

5、级联

添加级联操作

alter table 表名 add constraint 外键名称 
foreign key (外键字段名称) references 主表名称(主表列名称)
on update cascade on delete cascade  ;

级联删除

on update cascade

到此这篇关于mysql约束超详解的文章就介绍到这了,更多相关mysql约束内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐