首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏全栈程序员必看

    Django(15)关系

    删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: CASCADE:级联操作。 如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。 SET_NULL:设置为空。 如果的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 SET():如果的那条数据被删除了。 关系 之间的关系都是通过来进行关联的。而之间的关系,无非就是三种关系:一对一、一对多、多对多等。以下将讨论一下三种关系的应用场景及其实现方式。 这个中间分别定义了两个,引用到article和tag两张的主键。

    3.1K40编辑于 2022-09-19
  • 来自专栏java 微风

    mysql 查关联关系 (指定被引用,查哪些对其有引用)

    在一个业务功能中要求先清空一张基础(user)再插入一批新数据。 在删除过程中报错为其它引用,无法删除。 于是,查询库中哪些引用了 user 中的主键为。 从 INFORMATION_SCHEMA.KEY_COLUMN_USAGE 中查。 select * from INFORMATION_SCHEMA.KEY_COLUMN_USAGE where REFERENCED_TABLE_NAME='被引用名' 如图 红色框中是当前连接中的数据库 ,黄框中的是引用了 user 的其它,蓝色框中的是黄框中表的字段。 要想删除 user 中的数据,就要先删除后面 2 个框中的引用。

    4.8K10编辑于 2022-04-13
  • 来自专栏抠抠空间

    mysql清空有关联的

    第一种:(不要约束) 手动删除外约束; 删除数据 第二种:(保留约束) SET FOREIGN_KEY_CHECKS = 0;    TRUNCATE TABLE 名;   SET FOREIGN_KEY_CHECKS

    7.9K40发布于 2018-12-05
  • 来自专栏java达人

    oracle建、建主键、基本语法

    主键:唯一标识,不能为空,加快查询速度,自动创建索引 :约束内的数据的更新,从定义时可以发现 是和主键联系,数据类型要统一,长度(存储大小)要统一。 这样在更新数据的时候会保持一致性 -创建表格语法: create table 名( 字段名1 字段类型(长度) 是否为空, 字段名2 字段类型 是否为空 ); -增加主键 alter table 名 add constraint 主键名 primary key (字段名1); -增加: alter table 名 add constraint 键名 foreign key (字段名1) references 关联 (字段名2); 在建立表格时就指定主键和 create table varchar2(8) not null, constraint PK_T_STU primary key (STU_ID) ); 主键和一起建立

    4K50发布于 2018-01-31
  • 来自专栏小码农漫漫积累路

    MySQ-关系--修改结构-复制表-03

    foreign key 确定字段归属方 修改 修改名 增加字段 删除字段 修改字段 复制表 复制表结构+记录 利用条件实现仅复制表结构 今日数据库操作语句 创建数据库 拆分员工与部门信息成两张 多对多的关系,必须额外创建第三张,用来专门记录两种之间的关联关系 如果按一对一的思路来,两张都必须关联对方,都必须让对方先建立,那就建不了了,存的是关联关系,那就单独开一张,存关联关系 案例建立 foreign key 在MySQL中通过来建立之间的硬性关系 通常将关系字段称之为字段 确定字段归属方 一对多的字段,应该建在“多”的那一方 多对多的字段建在额外的第三张上 一对一的字段建在任意一方都行,但推荐建在查询频率较高的一方(字段必须保证唯一性) 有关系的注意点 在创建的时候,必须先创建被关联 插入数据的时候也应该先插入被关联数据 级联更新,级联删除 注意外的逗号,(逗号代表一个字段的结束)(还是不要忘了建的字段定义那块最后一个语句不要加 , 逗号) 虽然能够帮你强制建立关系,但也会给两行之间增加数据相关的约束 ?

    1.5K30发布于 2019-09-26
  • 来自专栏后端技术

    gorm指定和关联

    association_foreignkey和foreignkey的作用,此文总结一下 参考 https://juejin.im/post/5d42ba4a51882519ac30759f 不显式指定 则association_foreignkey是主键, foreignkey是名+ID ?

    7.8K50发布于 2019-12-24
  • 来自专栏远在上海

    FlowPortal.Net BPM 嵌套没有定义

    如果你在嵌套表里面做重复,需要定义一下,不然会报错:嵌套没有定义!为了确定嵌套中每一行的父行,需要在数据库中为嵌套定义指向其父。 需要在字表创建字段ParentID 点击找到ParentID字段,右键点击“Relationships”即可创建父的连接。

    1.1K30发布于 2019-02-26
  • 来自专栏别先生

    mysql如何添加一个

    1:创建一个父,主键作为子表的: 1 create table province( 2 pId int primary key auto_increment, 3 pName varchar (20) 4 ); 2:创建子表,是父的主键: 1 create table user( 2 userId int primary key auto_increment, 3 userName varchar (40), 4 pid int, 5 foreign key(pid) references province(pId) 6 ); 给一张添加,即给子表的添加主键的规则: 在子表声明一个字段pid int,用于作为子表的,foreign key(子表的字段) references 父名(父的主键的字段名); 3:当创建好数据时添加约束: alter table user add foreign key(pid) references province(pId); alter table 子表的数据名 add foreign key(子表的键名称) references 父的数据名称

    5.8K70发布于 2018-01-02
  • 来自专栏抠抠空间

    MySQL 如何删除有约束的数据

    SET FOREIGN_KEY_CHECKS=0; 删除,更新数据, 恢复 SET FOREIGN_KEY_CHECKS=1; 另:查看当前 FOREIGN_KEY_CHECKS的值 SELECT

    9.8K30发布于 2018-10-15
  • 来自专栏互联网杂技

    约束

    约束 foreign key 约束的要求: 父和字表必须使用相同的存储引擎,禁止使用临时; 数据库引擎只能是InnoDB; 列和参照列必须具有相似的数据类型,数字的长度或者是否有符号必须一样 ,字符长度可以不不一样; 列和参照列必须创建索引,参照列没有索引,mysql回自动创建索引; ----------- 下面创建两个数据 1(父)省份两个字段 id (主键) 省份名称 2(子表 )用户三个字段 id (主键) 用户名称 省份编号(对应省的主键id类型一样,因为需要把这个设置为约束) ------------------- 字表通过省份编号去在父中查询省份名称; - ----------- 如果要创建约束,那么在父最后加上一句 foreign key (省份编号字段) references 省份 (省份id); 这样就创建一个约束, 上面两个,也就是说用户中的省份标号是 ,相当于省份 中的id,那么用户的省份编号与省份的id字段类型必须一样; ------------- 添加的语法 ALTER TABLE tbl_name ADD [CONSTRAINT

    3K90发布于 2018-04-04
  • 来自专栏全栈程序员必看

    约束

    2.设置约束的两个之间会有 父子关系 ,即字表中外字段的取值范围 取决于 父      3.设置一定程度上降低了数据库的速度      4.字表中外字段的数据类型要与父中的数据类型一致 建立语法:[constraint 键名] foreign key (子表字段名 ) references 父 (父表字段名)        [on delete {restrict alter table 名 drop foreign key 键名;   注意:删除外后发现 desc 查看索引标志还在,其实也是一种索引,需要将索引删除才可以。 set null: on delete set null on update set null         当主表删除记录时,从字段值变成 null         当主表更新主键字段值时, 从字段值变成null      4.

    2.7K20编辑于 2022-09-06
  • 来自专栏python-爬虫

    django模型中有关系的删除相关设置

    0904自我总结 django模型中有关系的删除相关设置 一.一对一 例如有Author、AuthorDetail两 author = models.OneToOneField(to='Author :作者删除详情删除,详情删除作者保留 2)作者找详情用 related_name(detail),详情找作者用 字段(author) 3)db_constraint断开关联,on_delete (多的一方):出版社删除书不动,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint断开关联 ,on_delete规定逻辑关联删除动作,models.DO_NOTHING关联无动作 三.以外字段关联 1)断关联,删除关联表记录,键值置空 db_constraint=False, on_delete 2)正向找 字段,反向找 字段related_name 3)db_constraint断开关联,on_delete不存在(不设置,本质在第三张中设置,且一定是级联)

    4.3K20发布于 2019-09-11
  • 来自专栏全栈程序员必看

    【原创】关于自身触发器实现

    目前遇到这样一个定义: `t_girl`. ) REFERENCES `tb1` (`id`) ON DELETE CASCADE 目的是对于自己的另外一个字段进行约束, 其实这样看来, 后面的级联删除就没有必要了,因为针对的是同一张的同一条记录

    78920编辑于 2022-07-05
  • 来自专栏应用计算

    第三篇 的关联:SPL轻量级文件存储提速查询实践

    关联的一种情况是关联。一个的普通字段()和另一个的主键关联。比如订单与客户、运货商都是关联。在关联中是主键,具有唯一性,SPL 把理解成一个对象。 要注意,这里说的是逻辑上的主键,是在中取值唯一的字段,不一定是在物理上建立的 primary key。也不一定是物理上的 foreign key。另一种关联是主键关联。 下面,我们以订单、客户、城市、州和运货商为例,介绍 esProc SPL 外置数据提速关联的方法。 还要完成预关联,预先把用 run 转换成对应的记录,比如 A6:序 customer 的普通字段 city_id 被转换为 city 的记录。 2、思考:在自己熟悉的数据库中有没有通过关联的多个?是否可以用序号关联的方法来提速?

    20810编辑于 2025-09-23
  • 来自专栏千帆企业应用连接器

    金山轻自动跨同步

    有没有适合HR使用的工具,可以自动将表格中的数据进行跨同步,不需要手动复制粘贴呢?当然可以。推荐使用腾讯云HiFlow,可以实现金山轻自动同步。如何实现金山轻自动跨同步? 首先,我们需要进入腾讯云HiFlow官网,找到【金山轻自动跨同步】模板,点击立即使用。我们以上述场景作为案例,演示如何自动同步。 Step1:触发节点我们选择【金山文档轻-新增或修改的内容满足指定条件】,我们将查询条件设置为“手机号不为空”。这个时候,当有新的手机号填入的时候,则会触发此流程。 最后,当我们更新A时,数据也能在B中一自动跨同步。 是什么产品腾讯云HiFlow是腾讯云推出的零代码的自动化工作流程平台,目前已经实现了连接了比如企业微信、腾讯会议、腾讯文档、腾讯电子签、TAPD、乐享、兔小巢、微信小商店、企点、公众号、EC SCRM、

    1.5K52编辑于 2023-03-07
  • 来自专栏诡途的python路

    的设置

    关键词: | 索引 | InNoDB和MyISAM | 引用 | Mysql 设置的目的:保证数据的一致性! 一、的使用条件: ① 两个必须是InnoDB,MyISAM暂时不支持 #查看表类型 SHOW TABLE STATUS #查询结果的Engine字段下,一般默认InnoDB类型 ② test2创建test的索引,在test2下执行,test2为从,test为主 这一步也是博主自己刚开始研究是碰到的最大的坑, 引用一直选不了对应字段,可能是你没有设置索引 ③ 关系的两个的列必须是数据类型相似 ; #父更新子表更新方式 2、可视化界面设置 选中表—》关/系/ | F10 ——》外部 约束名自动生成不用管,重点是后面的更新和删除关键字 三、相关关键字含义 约束(2) 对父1)的含义: 在父上进行update/delete以更新或删除在子表中有一条或多条对应匹配行的候选时,父的行为取决于:在定义子表的时指定的on update/on delete子句

    3.8K30编辑于 2022-05-09
  • 来自专栏全栈程序员必看

    (FOREIGN KEY)

    的记录之间存在着三种关系:一对多、多对多、一对一的关系。 处理之间关系问题就会利用到FOREIGN KEY 多对一关系: 寻找之间的关系的套路 举例:雇员:emp 部门:dep part1: 1、 先站在emp的角度 2、去找emp的多条记录能否对应dep的一条记录。 此时就可以用到外了,在emp中新增一个dep_id字段,该字段指向dep的id字段 foreign key会带来什么样的效果? null, customer_id int unique, #该字段一定要是唯一的 foreign key(customer_id) references customer(id) #此时的字段一定要保证

    1.5K20编辑于 2022-09-07
  • 来自专栏小海怪python学习

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

    关系 在MySQL中,有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持约束的。的存在使得ORM框架在处理关系的时候异常的强大。 因此在底层,Django为Article添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个,记录着对应的作者的主键。 如果一个模型使用了。 如果对应的那条数据被删除了,那么这条数据也会被删除。 2.PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。 3.SET_NULL:设置为空。 如果的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果的那条数据被删除了。

    6.2K30发布于 2019-10-08
  • 来自专栏java达人

    mysql的

    在MySQL 3.23.44版本后,InnoDB引擎类型的支持了约束。 的使用条件: 1.两个必须是InnoDB,MyISAM暂时不支持(据说以后的版本有可能支持,但至少目前不支持); 2.列必须建立了索引,MySQL 4.1.2以后的版本在建立时会自动创建索引 ,但如果在较早的版本则需要显示建立; 3.关系的两个的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 的好处:可以使得两张关联 ,保证数据的一致性和实现一些级联操作; 的定义语法: [CONSTRAINT symbol] FOREIGN KEY [id] (index_col_name, ...) ON DELETE、ON UPDATE表示事件触发限制,可设参数: RESTRICT(限制外表中的改动) CASCADE(跟随改动) SET NULL(设空值) SET DEFAULT(设默认值

    7.7K70发布于 2018-01-31
  • 来自专栏JavaEdge

    MySQL约束

    其中就包括 1 主键(primary key或unique key) 又称主码,数据库中对储存数据对象予以唯一和完整标识的数据列或属性的组合。 比如,学生跟老师之间是教学关系,学生数据会有个属性叫指导老师(FK),而这个值就是对应到老师数据的老师代号(PK),学生的指导老师就是。 注意 : 不一定要与相应主键同名,只是在应用中为便于识别,当主键与相应属于不同关系时,往往取同名 作用 保持数据一致性,完整性,主要目的是控制存储在外中的数据。 使两张表形成关联,只能引用外表中的列的值或使用空值。 案例 如果不使用2的学号字段插了一个值(比如20140999999),但该值在1中并没有。 然而在设置时,你插入2学号字段的值必须要求在1的学号字段能找到。 同时,如果你要删除1的某个学号字段,必须保证2中没有引用该字段值的列,否则就没法删除。

    9.2K20编辑于 2022-11-29
领券