create table dept(
id int auto_increment comment 'ID' primary key,
name varchar(50) not null comment '部门名称'
)comment '部门表';
insert into dept (id,name)values (1,'研发部'),(2,'市场部'),(3,'财务部'),(4,'销售部'),(5,'总经办');
create table emp(
id int auto_increment comment 'ID' primary key,
name varchar(50) not null comment '姓名',
age int comment '年龄',
job varchar(20) comment '职位',
salary int comment '薪资',
entrydate date comment '入职时间',
managerid int comment '直属领导ID',
dept_id int comment '部门ID'
)comment '员工表';
insert into emp(id,name,age,job,salary,entrydate,managerid,dept_id) values
(1,'金庸',66,'总裁',20000,'2000-01-01',null,5),(2,'张无忌',20,'项目经理',12500,'2005-12-05',1,1),
(3,'杨逍',33,'开发',8400,'2000-11-03',2,1),(4,'韦一笑',48,'开发',11000,'2000-01-01',2,1),
(5,'常遇春',43,'开发',10500,'2004-09-07',3,1),(6,'小昭',19,'程序员鼓励师',6600,'2004-10-12',2,1);
如果我在这里把一号表删了
目前这两张表之间只是逻辑上存在着一层关系,现在未设置外键约束(物理外键),从而无法保证数据的一致性和完整性
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);
从表的外键列,引用的必须是主表的主键列或具有unique约束的列
添加外键之后,这时候就不能删除了,这样就保证了数据的一致性和完整性
alter table emp drop foreign key fk_emp_dept_id;