目录
数据库中要管理很多数据,但是这些数据是否正确、是否非法,光靠人力来检验是远远不够的。因此我们想让数据库拥有丰富的检验和校验能力,所以便引入了‘约束’!
约束:主要是用来对我们插入或 修改的数据进行校验和检查的。
效果:创建表时,可以指定某列不为空
create table student(id int not null, name varchar(20));
效果:指定某一列为唯一、不重复
create table student(id int unique,name varchar(20));
效果:指定插入数据时,name列为空,设为默认值
- create table student(id int, name varchar(20) default '未命名');
- insert into student(id) values(1);
- select * from student;
效果:设为主键的那一列数据,不能重复,不能为空
create table student(id int primary key, name varchar(20));
数据不能为空:
insert into student values(null,'张三');
数据不能重复:
- insert into student values(1,'张三');
- insert into student values(1,'张三');
当我们给一个属性设为主键时,插入数据就会比较麻烦,所以MySQL 提供了一个机制,可以自增主键!!!
- create table student(id int primary key auto_increment,name varchar(20));
- desc student;
咱们在插入数据的时候就不必手动设置值了(把这一列设为null即可),直接交给数据库来自动分配即可!!
- insert into student values(null,'张三');
- select * from student;
虽然自增主键,是能自动分配,但是我们也能手动设置的。
insert into student values(100,'李四'); insert into student values(null,'王五'); select * from student;
注:自增主键,是从最大值之后在进行增加的。
效果:把两张表关联起来
语法格式:
foreign key (字段名) references 主表(列)
用 foreign key 可以把两张表关联起来,便于我们判断,比如一个年级有 ‘Web 1班’, ‘Web 2班’, ‘Web 3班’。当一个学生说他是 ‘Web 5班’时,我们就能判断他不是这个学校的。
下面用代码进行详细说明
- --创建 class 班级表
- create table class(id int primary key, name varchar(20));
- --创建 student 学生表
- create table student(id int primary key,name varchar(20),classId int,foreign key(classId) references class(id));
注意:学生表里的每个记录,中包含的班级编号,得在班级表中存在!!否则插入数据就会报错。
如上就说明,班级表对学习表产生了约束!!
通常把约束别人的标称为父表,被约束的标称为子表
班级表:父表(parent)
学生表:子表(child)
所以,往student表里插入数据之前,先往class表中插入数据
- insert into class values(1,'Web1班'),(2,'Web2班'),(3,'Web3班');
- insert into student values(1,'张三',1),(2,'李四',2),(3,'王五',3);
- select * from student;
注意:
外键约束下,插入数据,也会触发查询,往学生表中插入新的数据,就会自动在班级表中查询,看这个 classId 是否存在。
这一过程就会浪费不少时间,为了节省时间我们可以创建索引提升效率,而添加主键就能创建索引。
所以,子表中引用父表的这一列,务必得是 priamry key,或者 unique
父表对子表约束:
子表对父表的影响:
效果:插入数据必须在 check设置的质内,否则报错
语法:
check(列名 = 值,...)
例如:创建一个学生表,其中性别设定填入的值为 男 或 女
create table student(id int,name varchar(20),sex varchar(1) check(sex = '男' or sex = '女'));
如果 sex列插入的数据是其他的,就会报错