目录
- 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!