约束分类

mysqlworkbench添加约束 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 (‘李四’,‘女’);