数据库约束
数据库约束的类型:
not null- 指示某列不能存储 null值。
unique- 保证某列的每行必须有唯一的值。
default - 规定没有给列赋值时的默认值。
primary key - not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标
识,有助于更容易更快速地找到表中的一个特定的记录。
foreign key - 保证一个表中的数据匹配另一个表中的值的参照完整性
null约束 :
创建表时,可以指定某列不为空
1. drop table if exists student; 2. create table student (id int not null,sn int,name varchar(20),qq_mail varchar(20));
unique约束(唯一约束):
指定sn列为唯一的、不重复的:
1. drop table if exists student; 2. create table student (id int,sn int unique,name varchar(20),qq_mail varchar(20));
default约束(默认值约束):
指定插入数据时,name列为空,默认值无名氏:
1. drop table if exists student; 2. create table student (id int,sn int ,name varchar(20) default '无名氏',qq_mail varchar(20));
primary key约束(主键约束):
指定id列为主键:
1. drop table if exists student; 2. create table student (id int primary key,sn int ,name varchar(20),qq_mail varchar(20));
对于整数类型的主键,常配搭自增长auto_increment来使用。插入数据对应字段不给值时,使用最大值+1。
1. drop table if exists student; 2. create table student (id int primary key auto_increment,sn int ,name varchar(20),qq_mail varchar(20)); 3. desc student; 4. insert into student values(1,1,'张三','********@qq.com'); 5. insert into student (sn,name,qq_mail)values(2,'李四','********@qq.com'); 6. select *from student;
foreign key约束(外键约束):
外键用于关联其他表的主键或唯一键,语法:
语法形式:
foreign key(字段名) references 主表(列)
1. create table class (id int primary key,name varchar(20)); 2. create table student(id int primary key,name varchar(20),class_id int,foreign key(class_id)references class(id));
这样就使得student和class产生了联系。而且在插入数据的时候,只能插入符合外键约束的数据:
1. insert into class values(1,'java1班'); 2. insert into class values(2,'java2班'); 3. select *from class;
class中的数据:
1. insert into student values(1,'张三',2); 2. insert into student values(2,'李四',1); 3. select *from student;
student中的数据:
也就是说张三class_id为2,也就是java1班,李四就是java2班的。这是我们插入一条在class中不存在的id:
insert into student values (3,'王五',100);
就会出现报错了,无法插入,这就体现了外键的约束。
还要注意的一点就是,外键约束约束的其实是双方,(我们可以把class看成主(父)表,student看成子表) ,除了上述关系外,如果我们想删除父表,也必须删除子表,否则无法删除:
drop table class;
因为约束的存在所以无法删除。要想删除就要先把子表删除。