MySQL之五大约束

约束分类
在这里插入图片描述
实体完整性(主键)

主键设置可以划分为两种

第一种 : 创建表语句时,添加主键约束
第二种 : 创建表完成之后,通过alter添加主键约束

下面是使用方式

第一种 : 创建表语句时,添加主键约束
create table person(
id int ,
name varchar(20),
primary key (id,name)
);
create table person1(
id int ,
name varchar(20),
primary key (id)
);
create table person2(
id int primary key,
name varchar(100) ,
);

第二种 : 创建表完成之后,通过alter添加主键约束

语法 : alter table 表名 add primary key(列名,列名…);

create table person3(
id int ,
name varchar(100),
);
比如要对person3表添加id列主键

alter table person3 add primary key(id);

主键自增

设置自增的两种方式 :
第一种 : 建表时,添加自增
第二种 : 创建表之后,添加自增

下面是使用方式

第一种 : 建表时,添加自增
create table person4(
id int auto_increment ,
name varchar(200),
primary key(id)
);
测试语句 :

insert into person4(name)values(‘测试’);

并未输入id的值,但是可以自动填充

第二种 : 创建表之后,添加自增

语法 : alter table 表名modify 主键列名 类型 auto_increment;

create table person5(
id int ,
name varchar(200),
primary key(id)
);

alter table person5 modify id int auto_increment;

测试语句 :
insert into person5 (name)values(‘测试’);
并未输入id的值,但是可以自动填充

设置自增的起始值
语法 : alter table 表名auto_increment=值;

create table person6(
id int auto_increment ,
name varchar(200),
primary key(id)
);
alter table person6 auto_increment=10000;
测试语句 :
insert into person6 (name)values(‘测试’);
Id值从10000开始

关联完整性(外键)

设置外键有两种方式 :
第一种 : 创建表时添加外键约束
第二种 : 创建完表之后,添加外键约束

下面是使用方式

第一种 : 创建表时添加外键约束
create table teacher(
id int ,
name varchar(20),
primary key (id)
);
create table student (
id int ,
name varchar(20),
teacher_id int ,
primary key (id),
– foreign key(外键列) REFERENCES 关联表(关联表中主键列)
foreign key (teacher_id) references teacher(id)
);
注意 : 引用student中添加外键列,指向teacher表,所以必须先创建teacher表才行
测试语句
添加一个讲师
insert into teacher (id,name) values(1,‘张老师’);
添加一个学生小明,学生通过teacher_id可以指向张老师
insert into student (id,name,teacher_id) values(1,‘小明’,1);
添加一个学生小红,teacher_id没有设置值
insert into student (id,name) values(2,‘小红’);
添加一个小黑,teacher_id指向一个不存在的讲师,报错
insert into student (id,name,teacher_id) values(3,‘小黑’,2);

第二种 : 创建完表之后,添加外键约束
create table student1 (
id int ,
name varchar(20),
teacher_id int,
primary key (id)
);
create table teacher1(
id int ,
name varchar(20),
primary key (id)
);

语法 : alter table 表名 add foreign key (外键列列名) references 指向的表名 (主键列列名);

alter table student1 add foreign key (teacher_id) references teacher1 (id);
测试语句

添加一个讲师
insert into teacher1 (id,name) values(1,‘张老师’);

添加一个学生小明,学生通过teacher_id可以指向张老师
insert into student1 (id,name,teacher_id) values(1,‘小明’,1);

添加一个学生小红,teacher_id没有设置值
insert into student1 (id,name) values(2,‘小红’);

添加一个小黑,teacher_id指向一个不存在的讲师,报错
insert into student1 (id,name,teacher_id) values(3,‘小黑’,2);

唯一约束unique

唯一约束是指定table的列或列组合不能重复,保证数据的唯一性。
唯一约束不允许出现重复的值,但是可以为多个null.

设置unique约束有两种方式 :
第一种 : 创建表时,添加unique约束
第二种 : 创建表之后,添加unique约束
下面是使用方式
第一种 : 创建表时,添加unique约束
create table temp (
id int ,
name varchar(20),
unique(id)
);

create table temp (
id int unique ,
name varchar(20)
);

添加一条没有id的数据
insert into temp (name)values(‘张三’);
再添加一条没有id的数据,可以添加(唯一约束,又不是不为空约束)
insert into temp (name)values(‘李四’);
添加一条id为1 的数据
insert into temp (id,name)values(1,‘王五’);
再添加一条id为1的数据,报错,因为已经有了id为1了,不可重复
insert into temp (id,name)values(1,‘赵六’);

第二种 : 创建表之后,添加unique约束
create table temp1 (
id int ,
name varchar(20)
);
alter table temp1 add unique (id);

添加一条没有id的数据
insert into temp1 (name)values(‘张三’);

再添加一条没有id的数据,可以添加(唯一约束,又不是不为空约束)
insert into temp1 (name)values(‘李四’);

添加一条id为1 的数据
insert into temp1 (id,name)values(1,‘王五’);

再添加一条id为1的数据,报错,因为已经有了id为1了,不可重复
insert into temp1 (id,name)values(1,‘赵六’);

非空约束 not null与 默认值 default

设置not null 与 default有两种方式 :
第一种 : 创建表时,添加约束
第二种 : 创建表之后,添加约束
下面是使用方式
第一种 : 创建表时,添加约束
create table temp2(
id int not null,
name varchar(30) default ‘abc’,
sex varchar(10) not null default ‘男’
);
测试语句 :
只添加id值,可以,因为name和sex都有默认值
insert into temp2 (id) values (1);

如果设置了值,默认值就不再设置
insert into temp2 (id,name,sex) values (2,‘张三’,‘女’);

注意 : 没有添加id的值,而id又设置不能为空,并且也没有默认值,所以报错
insert into temp2 (name,sex) values (‘李四’,‘女’);
第二种 : 创建表之后,添加约束
语法 : alter table 表名 modify 列名 数据类型 not null default 默认值;

create table temp3(
id int,
name varchar(30) ,
sex varchar(10)
);
alter table temp3 modify id int not null ;
alter table temp3 modify name varchar(30) default ‘abc’;
alter table temp3 modify sex varchar(10) not null default ‘男’;

测试语句 :
只添加id值,可以,因为name和sex都有默认值
insert into temp3 (id) values (1);

如果设置了值,默认值就不再设置
insert into temp3 (id,name,sex) values (2,‘张三’,‘女’);

没有添加id的值,而id又设置不能为空,并且也没有默认值,所以报错
insert into temp3 (name,sex) values (‘李四’,‘女’);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值