此时有两种方法,解决1.删除外键约束,删除该表,在重建外键约束--查询外键约束select TABLE_NAME,CONSTRAINT_NAME,CONSTRAINT_TYPE,R_CONSTRAINT_NAME from ALL_CONSTRAINTS WHERE constraint_type='R' and owner='SCOTT'; 删掉外键约束 alter table emp drop constraint fk_deptno; truncate  表后如果仍然想要关联原来的子表,重…
外键约束 在新表中添加外键约束语法: constraint 外键约束名称 foreign key(外键的字段名称) references 主表表名(主键字段名) 在已有表中添加外键约束:alter table 从表表名 add constraints 外键约束名称 foreign key(外键的字段名称) references 主表表名(主键字段名) 删除外键语法: alter table 从表表名 drop foreign key 外键名称; 级联操作: 注意: 在从表中,修改关联主表中不存在…
约束 外键约束 外键约束概念 让表和表之间产生关系,从而保证数据的准确性! 建表时添加外键约束 为什么要有外键约束 -- 创建db2数据库 CREATE DATABASE db2; -- 使用db2数据库 USE db2; -- 创建user用户表 CREATE TABLE USER( id INT PRIMARY KEY AUTO_INCREMENT, -- id NAME VARCHAR(20) NOT NULL -- 姓名 ); -- 添加用户数据 INSERT INTO USER VAL…
报错内容如:1701 - Cannot truncate a table referenced in a foreign key constraint 一.为什么要使用truncate 使用truncate截断表速度快,不仅可以清空表数据,而且可以使自增列重新从1开始 二.出现错误的原因 Mysql中如果表和表之间建立了外键约束,则无法删除表及修改表结构 三.解决方案 在Mysql中取消外键约束:  SET FOREIGN_KEY_CHECKS=0;     执行 truncate tablen…
两张表之间的关系: 一对一(两张表可以合并成一张表) 一对一用的比较少,多对一对外键设置unique约束可以实现一对一 一对多(例如:每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任) 多对多 多对多得创建第三张表 第三张表中创建两个外键 多对多表的创建:详见博客结尾 外键约束 创建外键 举个栗子: --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 --- 主表 CREATE TABLE classcharger( id TINYINT auto_incremen…
直接Ctrl + 鼠标左键 表名 就可以找到参照表(关联表)的名称 下面的是复杂的方法 这个就是关联的表 这里右键查看 可以查看到参照的表…
SET FOREIGN_KEY_CHECKS = 0 操作结束后 SET FOREIGN_KEY_CHECKS = 1…
外键约束对子表的含义:如果在父表中找不到对应的候选键,则不能对子表进行insert/update操作 外键约束对父表的含义:在父表上进行update/delete以更新或删除在子表中有一条或多条对应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的on update/on delete子句 action方式:在对父表进行update/delete操作时,子表匹配的列也对应的进行update/delete操作 set null方式:在对父表进行update/delete操作时,将子表对应…
一.外键约束 创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY KEY auto_increment, name VARCHAR (), age INT , is_marriged boolean -- show create table ClassCharger: tinyint() ); INSERT INTO ClassCharger (name,age,…
外键约束 创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY KEY auto_increment, name VARCHAR (20), age INT , is_marriged boolean -- show create table ClassCharger: tinyint(1) ); INSERT INTO ClassCharger (name,age…