场景 如果现在有两张表,一张表是文章表articles,一张表是分类表categories,其中在文章表中有一个分类字段category_id,现在想在删除分类表中的某一分类时,该分类下的所有文章也一起被删除...,那么这时候就可以用到外键约束 具体用法如下: 给文章表添加外键约束 $table- unsignedInteger('category_id')- comment('文章所属分类|select');...$table- foreign('category_id')- references('id')- on('categories')- onDelete('cascade'); 其中需要注意的是分类表categories...中的主键字段id与文章表articles中的外键字段category_id的数据类型或者是数据长度要保持一致,因为作为主键的id值是从1开始自增的,所以在被其绑定的外键字段的数据类型就不能使用integer...,而要改用unsignedInteger 以上这篇laravel5.6中的外键约束示例就是小编分享给大家的全部内容了,希望能给大家一个参考。
# 在setting设置外键 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给外键关系传值...,删除外键关系 反查: 在表关系里 related_name = ‘反查name’,自己不设置,django也会默认设置为class的小写名字+_set , ex: book_set....一对一关系赋值: class ModelStudy(View): ''' ClassRoom和ClassNumber是一对一关系,给外键传值 ''' def get(self, request):...(数据库的外键字段名字room_number_id)的值,将相对应的值直接赋值给该外键字段 class_number = ClassNumber.object.get("id=1").room_number...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发中取消外键约束就是小编分享给大家的全部内容了,希望能给大家一个参考。
1.标准的SQL语句 DML(Data Manipulation Language,数据操作语言) 语句:主要由select、insert、update和 delete 四个关键字完成。...2.2 外键 2.2.1 创建外键 (1)不带别名的外键,数据库自动生成 首先创建department表: CREATE TABLE department ( dept_name varchar...,用来设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变换规则的。...学习 cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表(子表)中也更新,主键表(父表)中的记录被删除,外键表(子表)中改行也相应删除。...而on update只能删除子表外键数据,不能删除父表主键数据,只能更新父表的主键,同时父子表数据都会被更新,但是在子表的外键上做更新操作无效。
SELECT @@FOREIGN_KEY_CHECKS; 查询当前外键约束是否打开 SET FOREIGN_KEY_CHECKS=1; 本地断开连接也会自动恢复全局默认的1 设置为1的时候外键约束是打开的...,设置为0的时候外键约束是关闭的; 删除数据的时候如果想把id序列也清空到1开始可以: TRUNCATE TABLE 表名; TRUNCATE TABLE acct_store; //这样不但将数据全部删除...,而且重新定位自增的字段 SELECT @@FOREIGN_KEY_CHECKS; SET FOREIGN_KEY_CHECKS=0;
KEY 主键约束P 唯一的标识出表的每一行,且不允许空值值,一个表只能有一个主键约束 FOREIGN KEY 外键约束R 一个表中的列引用了其它表中的列,使得存在依赖关系,可以指向引用自身的列...insert语句的影响: 插入数据的外键字段值必须在主表中存在,只有从表才有可能违反约束,主表不会。...外键约束对delete语句的影响: 删除主表数据时,如果从表有对该数据的引用,要先将从表中的数据处理好。主表才有可能违反约束。...外键约束对update语句的影响: 主从表都有可能违反外键约束,操作一个表必须将另一个表的数据处理好。 外键约束对DDL语句的影响: 删除主表时,才有可能违约约束。...,当主表中的一行数据被删除时,ORACLE自动将从表中依赖于它的记录外键也删除。
[1240] Constraints Constraints,约束的意思。通常用来约束加入表中的数据,如果与约束冲突,则行为会被终止。...INSERT INTO WHITETEST (TEST , ID) VALUES ( NULL , 13) 在数据仓库中我们执行上述语句,会返回如下结果: [1240] 因为列限制了TEST不为空,因此数据无法更新...//多个列定义约束 ...... ) C.FOREIGN KEY 一个表中的外键,通常可以用来连接另外一张表中的主键。...那么Product表中的ProductID就是主键,Fact表中的ProductID就是外键。 同时,外键的存在,可以防止意外删除。这对于数据仓库来说,很重要。...FOREIGN KEY (外键) REFERENCES 表名称(主键)//多个列定义约束 ...... ) D.CHECK CHECK通常可以用来约束限制列值的范围。
数据类型(长度) 约束, .... ) -- 查看某个数据库中的所有表 show tables; -- 查看表结构 desc 表名; -- 查看创建表的SQL语句,看到的是mysql生成的语句...; 外键约束 建表时添加外键约束 CREATE TABLE 表名( 列名 数据类型 约束, ......CONSTRAINT 外键名 FOREIGN KEY (本表外键列名) REFERENCES 主表名(主表主键列名) ); 删除外键约束 ALTER TABLE 表名 DROP FOREIGN...KEY 外键名; 建表后单独添加外键约束 ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY (本表外键列名) REFERENCES 主表名(主键列名); 外键的级联更新和级联删除...insert、update、delete 之前或之后触发并执行触发器中定义的 SQL 语句。
外键字段与主表主键字段类型完全一致 外键字段与主表主键字段基本属性相同 如果是在表后增加外键,对数据有要求(从表数据与主表的关联关系) 外键只能使用innodb存储引擎,myisam不支持 12.4...外键约束概念 外键约束主要约束主表操作,从表仅约束不能插入主表不存在的数据,外键约束约束了例如: 从表插入数据,不能插入对应主表主键不存在的数据 主表删除数据,不能删除被从表引入的数据 外键约束保证了数据的完整性...(主表与从表数据一致),外键强大的数据约束作用可能导致数据在后台变化的不可控,所以外键在实际开发中较少使用 12.5 外键约束模式 三种约束模式: district:严格模式,默认的,不允许操作 cascade...:级联模式,一起操作,主表变化,从表数据跟随变化 set null:置空模式,主表变化(删除),从表对应记录设置为空,前提是从表中对应的外键字段允许为空 添加外键约束模式: 基本语法: add foreign...key() references () on ; 通常在进行约束时候的时候,需要指定操作:update和delete 常用的约束模式:on update cascade
) FOREIGN KEY(foreign key:外键) REFERENCES(references:引用/参照/关联) 第二种添加外键约束的方式:在表格创建时没有添加外键约束,之后通过修改表格添加外键约束...设计从表可以有两种方案: 方式1:在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;即:字段 字段类型 unique, 方式2:给t_card表的主键添加外键约束...:在创建表格的时候同时添加外键约束。...) FOREIGN KEY(foreign key:外键) REFERENCES(references:引用/参照/关联) 第二种添加外键约束的方式:在表格创建时没有添加外键约束,之后通过修改表格添加外键约束...注意:在执行脚本时需要先行核查当前数据库中的表是否与脚本文件中的语句有冲突! 例如在脚本文件中存在create table a的语句,而当前数据库中已经存在了a表,那么就会出错!
自动增长 unique与primary key的区别 简单的讲,primary key=unique+not null 具体的区别: (1) 唯一性约束所在的列允许空值,但是主键约束所在的列不允许空值。...(2) 可以把唯一性约束放在一个或者多个列上,这些列或列的组合必须有唯一的。但是,唯一性约束所在的列并不是表的主键列。 (3) 唯一性约束强制在指定的列上创建一个唯一性索引。...(4) 建立主键的目的是让外键来引用. (5) 一个表最多只有一个主键,但可以有很多唯一键 存在唯一键冲突时,避免策略 insert ignore insert ignore会忽略数据库中已经存在的数据...如果有两个事务并发的执行同样的语句,那么就会产生death lock,如 img 解决办法: 1、尽量对存在多个唯一键的table使用该语句 2、在有可能有并发事务执行的insert 的内容一样情况下不使用该语句...参考 Mysql中unique与primary约束的区别分析(转) MySQL避免插入重复记录:唯一性约束 MySQL优化–INSERT ON DUPLICATE UPDATE死锁 ---- 我是蜗牛
约束设计标准 1、 主键的内容不能被修改。 2、外键约束一般不在数据库上创建,只表达一个逻辑的概念,由程序控制。...3、 禁用数据库外键 4、命名 a) 主键约束:默认PRIMARY; b) unique约束:UK_ c) check约束:CK_ d) 外键约束...2、SELECT语句只获取需要的字段,禁止使用SELECT * FROM语句,这是有效防止新增字段对应用逻辑的影响,还能减少对性能的影响; 3、INSERT语句必须显式的指明字段名称,不使用INSERT...6、写到应用程序里的SQL语句,禁止一切DDL操作,如对这些权限有要求,必需与DBA协商同意方可使用 7、WHERE条件中必须使用合适的类型,避免MySQL进行隐式类型转化,如ISENDED=1,字段类型是...10、避免使用存储过程、触发器、函数等,容易将业务逻辑和DB耦合在一起,并且MySQL的存储过程、触发器、函数中存在一定的bug。 11、使用合理的SQL语句减少与数据库的交互次数。
(简称PK) 外键约束(foreign key):…(简称FK) 检查约束(check):注意Oracle数据库有check约束,但是mysql没有,目前mysql不支持该约束。...username varchar(255) ); 外键约束:foreign key 外键主要是维护表之间的关系的,主要是为了保证参照完整性,如果表中的某个字段为外键 字段,那么该字段的值必须来源于参照的表的主键...外键可以为NULL 被外键引用的字段不一定是主键,但至少具有unique约束。...InnoDB 优点:支持事务、行级锁、外键等。这种存储引擎数据的安全得到保障。...I:隔离性:事务A与事务B之间具有隔离。 D:持久性:持久性说的是最终数据必须持久化到硬盘文件中,事务才算成功的结束。
影响行数 = 0,表示插入记录和表中记录存在主键或唯一索引冲突,并且 insert duplicate 语句 update 字段列表中每个字段的字段值和冲突记录中对应的字段值一样。...影响行数 = 2,表示插入记录和表中记录存在主键或唯一索引冲突,但是 insert duplicate 语句 update 字段列表中的字段值和冲突记录中的字段值不一样,插入语句会更新表中冲突的第 1...旧记录用于第 3 步中删除冲突记录,以及判断需要把插入记录中的哪些字段更新到表中。 这一步和 insert duplicate 语句也是一样的,因为在这一步它们执行的是同一段代码,兄弟俩还没有分家。...使用更新旧记录方式,需要同时满足 3 个条件: 条件 1,第 2 步中报记录冲突的那个索引是表中最后创建的唯一索引(也可能是主键)。 条件 2,表中的所有字段,都没有被其它表的字段作为外键约束。...外键约束和删除触发器都很少使用,不展开讲了。 4. 总结 2.
我们选择某一列作为主键,但是并不排除其他属性不需要维护,可能需要用到唯一键来限定,选择其他列作为唯一键,与主键配合起来,能够保证一些数据冲突。...外键foreign key 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。...,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。...因为此时两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。 解决方案就是通过外键完成的。...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。
MySQL的基本索引类型 索引的优缺点 事务 事务的定义 事务的性质 drop、delete与truncate 相同点 不同点 场景使用 超健、候选键、主键、外键 超健 候选键 主键 外键 视图...FOREIGN KEY: 用于预防破坏表之间连接的动作,也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。 CHECK: 用于控制字段的值范围。...场景使用 不再需要一张表的时候,用drop 想删除部分数据行时候,用delete,并且带上where子句 保留表而删除所有数据的时候用truncate 超健、候选键、主键、外键 超健 在关系中能唯一标识元组的属性集称为关系模式的超键...主键 数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空值(Null)。 外键 在一个表中存在的另一个表的主键称此表的外键。...在查询完数据的时候就把事务锁起来,直到提交事务 实现方式:使用数据库中的锁机制 乐观锁 假设不会发生并发冲突,只在提交操作时检查是否违反数据完整性 在修改数据的时候把事务锁起来,通过version
: 零填充约束 数据库中有三个完整性: 域、实体、参照完整性 域(列)完整性: 域完整性是对数据表中字段属性的约束 实体完整性在MySQL中实现: 通过主键约束和候选键约束实现的 参照完整性: 也就是说是...- 被外键约束的列,取值必须参照其主表列中的值 - 注意:通常先创建主表,再创建从表 添加外键约束 - create table emp(  ...,系统会自动地生成一个外键的名称。...- 使用 show create table 表名 查看具体的外键名称 设置外键中的级联关系 - on delete cascade: 删除主表中的数据时,从表中的数据随之删除 - on update...); 注意: - 插入数据时,先插入主表的数据,再插入从表的数据 - 删除数据时,先删除从表的数据,再删除主表的数据 数据库的设计 主键约束 自增长约束 外键约束(慎用) 唯一约束 非空约束
Oralce的二维表操作 –创建表并同时添加约束 –主键约束 –非空约束 –检查约束 –唯一约束 –外键约束 –简单的表创建和字段类型 –简单的创建语句: create table student...values(5,‘李四003’,18,‘男’,‘唱歌’,‘657889905’,3); –使用外键: –作用:当在子表中插入的数据在父表中不存在,则会自动报错。...–概念:当一张表的某个字段的值需要依赖另外一张表的某个字段的值,则使用外键约束。 –其中主动依赖的表称为子表,被依赖的表称为父表。外键加在子表中。...alter table 表名 drop constraints 外键约束名 –外键选取: –一般选取父表的主键作为子表的外键。...–外键的缺点: –无法直接删除父表数据,除非级联删除 –级联删除:在添加外键约束时,使用关键字 on delete cascade –使用:当删除父表数据时,自动删除子表相关所有数据。
· 唯一 · 主、外键 · 不为空 · 表之间的关联字段 · 查询比较频繁的字段 6:索引类型有哪些?...- 交叉连接: 笛卡尔效应,显示的结果是链接表数的乘积。 11:主键和外键的区别?...· 主键在本表中是唯一的、不可唯空的,外键可以重复可以唯空; · 外键和另一张表的主键关联,不能创建对应表中不存在的外键。 12:在数据库中查询语句速度很慢,如何优化?...· 第一范式:列不可再分 · 第二范式:行可以唯一区分,主键约束 · 第三范式:表的非主属性不能依赖与其他表的非主属性外键约束,且三大范式是一级一级依赖的,第二范式建立在第一范式上,第三范式建立第一第二范式上...delete区别 - TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。
多表操作 外键约束 添加外键 语法 注意 表与表之间的关系 子查询的缺陷 一对多的关系 一对多的建表原则 多对多的关系 多对多的建表原则 一对一的例子 一对一的建表原则 多表案例分析 多表查询...---替代级联删除 join语句中使用USING代替on---键值同名 union联合查询 union all可以查询出所有,不进行去重操作 内连接与外连接的区别 外键约束 作用:保证多表之间的数据完整性...这个时候就需要在多表之间添加外键约束 ---- 添加外键 语法 在新表中添加外键约束语法: constraint 外键约束名称 foreign key(外键的字段名称) references 主表表名(...主键字段名) 在已有表中添加外键约束:alter table 从表表名 add constraints 外键约束名称 foreign key(外键的字段名称) references 主表表名(主键字段名...---- 右外连接 恰与左连接相反,返回右表中的所有行,如果右表中行在左表中没有匹配行,则结果中左表中的列返回空值。
cascade, /*定义Cno为外键参考course表的主键Cno,并且实现级联删除SC表中相应的元组 */ ); 2....删除约束 删除主键约束:alter table 表名 drop primary key; 删除外键约束:alter table 表名 drop foreign key 外键(区分大小写);.../school/student' (errno: 150 - Foreign key constraint is incorrectly formed) 查了下资料,发现 MySQL建立外键的字段必须和引用表的字段一模一样的类型...这里我创建外键的时候 sno 中有些表有主键约束,有些却没有,所以当我删除主键约束的时候它会提示外键被错误建立起来了。但我不明白为什么建立外键的时候没有报错。...(二)触发器 MySQL包含对触发器的支持。触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,即表的操作事件触发表上的触发器的执行。
领取专属 10元无门槛券
手把手带您无忧上云