NULL:非空约束
NOT NULL
创建表时,指定某列不能为空,当插入值为空(包括未设置默认值的指定列插入)时插入失败。
以创建学生表为列:
create table student (
id int not null,
name varchar(20),
score float(5,2)
);
设置id列非空,当插入行记录id列的值为null时会报错,当插入行记录仅有name、score值时也会报错。
UNIQUE:唯一约束
UNIQUE
创建表时,指定某列不能重复出现,即表所有行记录中任意该列的值除自身外不和其他任何行记录的该列的值相同。
同样以创建学生表为例:
create table student (
id int unique,
name varchar(20),
score float(5,2)
);
对于上述学生表,若执行以下sql语句便会报错,因为id设置了UNIQUE约束,不能重复
insert into student values
(1, "大傻春", 30,2),
(2, "王旺", 29.3),
(1, "haihai", 45.1);
DEFAULT:默认值约束
DEFAULT 值
创建表时可对列设置默认值,当插入行记录不包含该列时,自动插入默认值(插入值为null时不触发)避免该列为空,或达到简化代码的目的
create table student (
id int,
name varchar(20),
score float(5,2) default 0
);
PERIMARY KEY:主键约束
PERIMARY KEY [AUTO_INCREMENT]
创建表时,设置某列为主键,主键值不能为空,主键值不能重复,一个表仅能有一个主键
create table student (
id int primary key,
name varchar(20),
score float(5,2)
);
可搭配auto_increment使用,当掺入行记录不包括主键时,自动插入最大值+1。
FOREIGN KEY : 外键约束
FOREIGN KEY (列) REFORENCES 主表(列)
创建表时,设置某列为外键,使此表为父表的子表
- “REFORENCES 主表(列)”中的列需在父表中具有唯一属性(主键、UNIQUE)
- 外键中列的数据类型必须和父表中主键的数据类型相同
- 外键可以定义多个,外键中列的个数必须和父表中列的数目相同,一一对应
create table score (
student_id int,
score float(5,2),
foreign key (student) reforences student(id)
);
设置后,外键的值必须是在主键中出现,主表不可先于子表删除
check约束
CHECK (表达式)