首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel5.6约束示例

场景 如果现在有两张表,一张表是文章表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约束示例就是小编分享给大家全部内容了,希望能给大家一个参考。

1.7K31

django在开发取消约束实现

# 在setting设置 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给关系传值...,删除外关系 反查: 在表关系里 related_name = ‘反查name’,自己不设置,django也会默认设置为class小写名字+_set , ex: book_set....(数据库字段名字room_number_id)值,将相对应值直接赋值给该字段      class_number = ClassNumber.object.get("id=1").room_number...ModelStudy(View): ''' Students和Teachers是多对多关系 ''' def get(self, request): ''' 两情况 ''' # 主类(所在类...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发取消约束就是小编分享给大家全部内容了,希望能给大家一个参考。

3.6K10
您找到你想要的搜索结果了吗?
是的
没有找到

【说站】mysql约束作用

mysql约束作用 1、约束是保证一个或两个表之间参考完整性,是构建在一个表两个字段或两个表两个字段之间参考关系。 2、通过约束,确保表格之间数据完整性和准确性。...实例 -- 约束操作 -- 关键字 foreighn key -- 概述:就是让两个以及多个表之间建立联系 -- 创建表时加入 CREATE TABLE tab( id int PRIMARY...KEY , -- 主键id 也是连接tab表 age INT );   -- 删除外约束 ALTER TABLE     tab -- 表名 DROP FOREIGN KEY     tab_tab1..._id; -- 键名称   -- 创建表后添加约束 ALTER TABLE tab -- 从表 add CONSTRAINT tab_tab1_id  -- 键名 FOREIGN KEY (t_id...) -- 列名 REFERENCES tab1(id); -- 主表(列名) 以上就是mysql约束作用,希望对大家有所帮助。

4.5K20

【MySQL】约束删除和更新总结

约束删除/更新行为 行为 说明 NO ACTION 当在父表删除/更新对应记录时,首先检查该记录是否有对应,如果有则不允许删除/更新。...(与NOT ACTION一致) CASCADE 当在父表删除/更新对应记录时,首先检查该记录是否有对应,如果有,则也删除/更新子表记录。...SET NULL 当在父表删除对应记录时,首先检查该记录是否有对应,如果有则设置该子表键值为null(这就要求该允许取null)。...id改为6,emp表id也会跟着改变 当我们删除父表id为6,我们可以看到子表emp存在外关联数据也会被删除。...-- 添加约束并指定删除和更新行为 alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references

32610

MySQL数据库——表约束(非空约束、唯一约束、主键约束约束)

目录 1 表约束 约束,是对表数据进行限定,保证数据正确性、有效性和完整性,约束分为以下几类: 主键约束:primary key 非空约束:not null 唯一约束:unique 约束:foreign...UNIQUE ); 注意:MySQL唯一约束限定值可以有多个null 2)删除唯一约束: -- alter table stu modify number varchar(20); 不同于非空约束删除方法...以上仍然存在一个问题,当在员工表输入不存部门时,数据依然可以添加,不符合实际,因此,这里就可以通过使用约束来解决。 【概念】什么是约束?...,就是从表与主表主键对应那一列,如:员工表dep_id,其中,主表是一方,用来约束别人表,从表可以是多方,被别人约束表。 注意:可以为NULL,但是不能是不存在键值。 ?...,同时希望自动改动员工表id,这时就需要进行级联操作,需要在添加时候设置级联: 添加级联操作:ALTER TABLE 表名称 ADD CONSTRAINT 键名称 FOREIGN KEY (

13.6K21

MySQL学习之路:数据完整性-约束

PRIMARY KEY 又称为主键约束,定义表构成主键一列或多列。 主键用于唯一标识表每条记录,作为主键字段值不能为NULL且必须唯一,可以是单一字段,也可以是多个字段组合。...CHECK约束是列输入数据值验证规则,列输入数据必须满足CHECK约束条件,否则无法写入数据库。...REFERENCES category(cid); Query OK, 0 rows affected (0.08 sec) Records: 0 Duplicates: 0 Warnings: 0 约束级联更新和删除...约束实现了表间引用完整性,当主表中被引用列值发生变化时,为了保证表间数据一致性,从表与该值相关信息也应该相应更新,这就是约束级联更新和删除。...SET NULL:更新和删除操作表记录时,从表相关记录对应值设置为NULL。 NO ACTION:不进行任何操作 RESTRICT:拒绝主表更新或修改关联列。

19820

mysql-关系

介绍 因为有foreign key约束,使得两张表形成了三了关系: 多对一 多对多 一对一 重点理解如果找出两张表之间关系 分析步骤: #1、先站在左表角度去找 是否左表多条记录可以对应右表一条记录...这种情况很简单,就是在左表foreign key右 表基础上,将左表字段设置成unique即可 表关系 (1)书和出版社   一对多(或多对一):一个出版社可以出版多本书。...references press(id) on delete cascade on update cascade); Query OK, 0 rows affected (0.04 sec) 先往主表插入记录...爬虫技术、linux高级运维 lisi: python全栈开发、linux高级运维 wangwu:web前端、爬虫技术、linux高级运维 zhuliu:python全栈开发 在author2book表插入相应数据...references user(id) on delete cascade on update cascade); Query OK, 0 rows affected (0.06 sec) 插入用户表记录

75530

MySQL实战七:你不知道约束使用!

,用来设置当主键表被参考列数据发生变化时,响应字段变换规则。...学习 cascade 表示级联操作,就是说,如果主键表中被参考字段更新,表(子表)也更新,主键表(父表)记录被删除,表(子表)改行也相应删除。...上述on delete cascade换成on update cascade,可以发现只能更新父表主键,同时父子表数据都会被更新,但是在子表上做更新操作无效!...,删除父表主键数据会将子表联同删除,删除子表数据不影响父表。...而on update只能删除子表数据,不能删除父表主键数据,只能更新父表主键,同时父子表数据都会被更新,但是在子表上做更新操作无效。

4.3K20

轻松学习SQL约束核心原理和实用技巧

SQL 约束-约束简介约束(FOREIGN KEY,缩写 FK)是用来实现数据库表参照完整性。...它是指表某个字段值依赖于另一张表某个字段值,而被依赖字段必须且有主键约束或者唯一约束。被依赖表通常称之为父表或者主表,设置约束表称为子表或从表。...相关概念主键:可以唯一标识一条记录:从表与主表主键对应字段主表:所指向表,约束其他表表从表:所在表,被约束表价值:建立主表与从表关联关系,为两个表数据建立连接,约束两个表数据一致性和完整性建立约束创建表时添加约束...id=2部门DELETEFROMdeptWHEREid=2#查看从表数据是否同时被删除SELECT*FROMemp_part总结SQL 约束是一参照完整性约束,它用于确保两个表之间数据一致性...当在子表插入或更新数据时,约束确保所提供键值必须在父表相应主键或唯一键值范围内。如果父表不存在相应值,则操作将失败,从而确保了数据完整性和一致性。

17910

SQL反模式学习笔记5 约束【不用钥匙入口】

目标:简化数据库架构 一些开发人员不推荐使用引用完整性约束,可能不使用原因有一下几点: 1、数据更新有可能和约束冲突; 2、当前数据库设计如此灵活,以至于不支持引用完整性约束...反模式:无视约束,即不使用约束 省略约束能使得数据库设计更加简单、灵活,或者执行更加高效,但是你不得不在其他方面付出相应代价, 必须增加额外代码来手动维护引用完整性...(通常这样需求是为了查找那些孤立行数据) 2、有没有一简单方法来判断在一张表数据是否也在第二张表存在? (这么做是用来确认父记录切实存在。...合理使用反模式: 如果数据库产品不支持约束功能,则不得不使用别的方法来保持引用完整性,比如使用监控脚本。 同样也存在一些极度灵活数据库设计,无法用来表示其对应关系。...在执行更新和删除2个操作任意1个是,数据库都会自动修改多张表数据, 引用状态在操作之前和之后都保持完好。

80530

MySQL 外码约束原理:如何解决数据库添加数据时产生外码(约束

文章目录 前言 一、插入新数据时报错约束? 二、对于出错 SQL 语句分析 三、对于外码约束分析 四、如何处理约束?...本篇文章带你进一步来深度剖析,并带着你思路来设计解决方案。 ---- 说明:本次案例案例情景是传统数据库表:学生-课程数据库。 一、插入新数据时报错约束?...我们在 Course 表插入课程号为 1 数据时提示违反了约束,插入命令如下: insert into course(cno,cname,cpno,ccredit) values('1','数据库...三、对于外码约束分析 我们根据数据库定义参照完整性规则得知: cpno 取值不为空情况下(如上 cpno=‘5’),与其对应主键 cno 在参照表必须存在。...但是我们反观上面操作,第一个插入就是 cno=‘1’ 数据,cno=‘5’ 还没有插入,很显然不满足参照完整性规则。 四、如何处理约束

3K20

Django学习-第七讲:django 常用字段、字段属性,和表关系、操作

和表关系 在MySQL,表有两引擎,一是InnoDB,另外一是myisam。如果使用是InnoDB引擎,是支持约束存在使得ORM框架在处理表关系时候异常强大。...因此这里我们首先来介绍下在Django使用。 类定义为class ForeignKey(to,on_delete,**options)。...即只要这条数据引用了那条数据,那么就不能删除外那条数据。 3.SET_NULL:设置为空。如果那条数据被删除了,那么在本条数据上就将这个字段设置为空。...如果那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果那条数据被删除了。...那么将会获取SET函数值来作为这个值。SET函数可以接收一个可以调用对象(比如函数或者方法),如果是可以调用对象,那么会将这个对象调用后结果作为值返回回去。

3.9K30

oracle基础|数据库如何设计|数据库范式|数据库主键和|数据库约束

目录 一、数据库设计 二、数据库六范式 第一范式: 第二范式: 第三范式: 三、主键和 主键: : 四、完整性约束 五、建表 六、oracle数据库多种数据结构 ---- 一、数据库设计...,要求这几个列值联合在一起是非空唯一 : 1.表某一个列声明为列,一般这个值都会引用于另外一张表主键列值(有唯一约束列就可以,不一定非要引用主键列) 2.另外一张表主键列中出现过值都可以在外列中使用...3.列值也可以为空,提前是这个列在表不做主键,因为我们也可以把表列当做主键来使用(只有满足非空唯一要求就可以) 4.如果把B表联合主键值引用到A表,因为是俩个列在B...表做联合主键,那么A表引用过来时候也要把俩个列值都引用过来,那么它们在A表中就会作为一个联合出现 四、完整性约束 实体完整性: 引用完整性 列级完整性 用户自定义 五、建表 1.映射实体---...-表 2.映射属性----列 3.添加约束 4.描述关系信息() 六、oracle数据库多种数据结构 1.表结构 存储数据 2.视图 一张表或多张表数据字节

65940

多表间关系-一对多-多对多-一对一-约束

多表间关系-一对多-多对多-一对一-约束 1. 表关系概述 现实生活,实体与实体之间肯定是有关系,比如:老公和老婆,部门和员工,用户和订单、订单和商品、学生和课程等等。...字段值必须为主表主键值,若为其他值,则没有意义. image-20200529101003797 用于限制字段取值必须为主表主键约束叫做-约束. 2....两建表原则: 唯一:主表主键和从表(唯一),形成主外关系,唯一UNIQUE 是主键:主表主键和从表主键,形成主外关系 5....约束 5.1 什么是约束 一张表某个字段引用另一个表主键 主表:约束别人 副表/从表:使用别人数据,被别人约束 5.2 创建 新建表时增加:[CONSTRAINT] [约束名称...-- 主表名(主键字段名) 表示参照主表某个字段 已有表增加:ALTER TABLE 从表 ADD [CONSTRAINT] [约束名称] FOREIGN KEY (字段名) REFERENCES

5.6K20

MySQL创建错误:1215 Cannot add the foreign key constraint

引言: MySQL中经常会需要创建父子表之间约束,这个约束是需要建立在主外基础之上,这里解决了一个在创建主外约束过程碰到一个问题。 1....碰到错误 在创建之时,使用SQL和碰到错误信息如下: alter table `product' add CONSTRAINT `sid_ref` FOREIGN KEY (`sid`)...REFERENCES `sealer` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION 碰到错误信息如下: 无法正确插入约束。...问题分析 主外更多是某表主键与子表某个列进行关联,要求是具备相同数据类型和属性,问题会不会出现在这里?...解决办法 修改product.sid数据类型,添加unsigned和字段长度,将其设置为相同即可。 5.

2.4K50
领券