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

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

外键和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。...第一个参数是引用的是哪个模型,第二个参数是在使用外键引用的模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等。这里以一个实际案例来说明。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。如果设置这个选项,前提是要指定这个字段可以为空。 4.SET_DEFAULT:设置默认值。...如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果外键的那条数据被删除了。

4K30

Django 外键引用另一个表中的多个字段

在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model...添加一个 product 字段作为外键,并使用 MultipleFieldPrimaryKeys 选项来定义复合主键:class sales_process(models.Model):​ prospect...划重点Django 不直接支持复合外键,但可以通过添加唯一约束、使用中间表或在查询中使用逻辑约束来实现类似效果。

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

    Django中基表的创建、外键字段属性简介、脏数据概念、子序列化

    如两张表建立了一对一外键字段,外键在A表,那么先往B表写数据就更合理。...更合理) """ Django orm中外键字段属性详解 在建表之前我们对外键字段属性进行了解: 1)related_name在外键中设置外键反向查询的字段名:正向找字段名,反向找related_name...,假设A表依赖B表,B记录删除,A表的外键字段不做任何处理 例子:作者被删了,作者的书还存在,书还是该作者写的;出版社没了,出版社出版的书还在 SET_DEFAULT:假设A表依赖B表,B记录删除,A表的外键字段重置为...例子:部门没有了,部门员工里的部门字段改为未分组部门的id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系中的多个外键 3)db_constraint...子序列化的使用方法及注意事项: 1)只能在序列化中使用 2)字段名必须是外键(正向反向都可以)字段,相对于自定义序列化外键字段,自定义序列化字段不能参与反序列化,而子序列化必须为外键名,子序列化字段不写入数据库

    4.3K30

    C# WPF MVVM开发框架Caliburn.Micro 关于Conventions⑧

    其他需要知道的事情 除了实例化视图外,GetOrCreateViewType还将在视图上调用InitializeComponent(如果存在)。...每当您使用UIElement上的View.Model attached属性进行ViewModel首次合成渲染时,都会调用定位器以查看合成的ViewModel应如何在UI中的该位置进行渲染。...我不提供这种开箱即用的实现,因为它不能保证在Silverlight中成功。原因是Silverlight不允许您获取私有字段的值,除非调用代码是定义字段的代码。...除了在ItemsControl上绑定ItemsSource外,ApplyBinding函数还检查ItemTemplate、DisplayMemberPath和ItemTemplateSelector(WPF...这些元素约定允许开发人员在各种情况下提供尽可能多或尽可能少的信息,允许框架适当地填充缺少的细节。

    2.8K20

    MySQL——函数与约束的讲解

    而在数据库中,存储的都是入职日期,如 2000-11-12 ,那如果快速计 算出天数呢? 2). 在做报表这类的业务需求中 , 我们要展示出学员的分数等级分布。...而要想解决这个问题就得通过数据库的 外键约束。 ---- (2)语法 1). 添加外键 CREATE TABLE 表名( 字段名 数据类型, ......[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) ); ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN...KEY (外键字段名) REFERENCES 主表 (主表列名) ; 案例 : 为 emp 表的 dept_id 字段添加外键约束 , 关联 dept 表的主键 id 。...具体的删除 / 更新行为有以下几种: 具体语法为: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名

    25520

    excel常用操作大全

    如果您在原始证书编号后添加19,请在B1单元格中写入:=A1 '13 ',然后按回车键。 2.如何在文件下拉窗口底部设置最近运行的文件名数量?...如果您需要在表格中输入一些特殊的数据系列,如物料序列号和日期系列,请不要逐个输入。为什么不让Excel自动填写它们呢?...如果您可以定义一些常规数据(如办公室人员列表),您经常需要使用这些数据作为将来自动填充的序列,这难道不是一劳永逸的吗?...定义名称有两种方法:一种是选择单元格区字段,直接在名称框中输入名称;另一种方法是选择要命名的单元格区字段,然后选择插入\名称\定义,然后在当前工作簿的名称对话框中单击该名称。...27.如何在公式中快速输入不连续的单元格地址? 在SUM函数中输入一长串单元格区场是很麻烦的,特别是当该区域由许多不连续的单元格区场组成时。此时,按住Ctrl键选择不连续区域。

    19.3K10

    MyBatis中的复杂映射

    例如有以下Java对象和数据库表Street:         对象中的外键属性名为“districtId”而数据表中的外键字段名为“district_id”这时,可以编写以下SQL完成映射: 中只有CategoryId外键 Category表中有Name字段 对象中需要跨表获取数据         针对上述需求,我们可以把MyBatis中的Movie查询按如下方式实现。...,无法填充到某一个实体中,我们还可以把resultType(返回结果类型)声明为hashmap,这时,查询到的每一行数据都会封装到一个HashMap集合中,键就是字段名,...4.1.1 外键对象映射 (1)通过join关联         下面的示例中:select语句使用了join把外键表相关数据一并查询了出来;通过resultMap元素,定义了查询结果字段与Java对象之间的映射填充关系...column属性是一对多关系中一方被外键引用的字段名(通常是主键字段名),select属性则是根据外键获取多方集合的查询名称,在上述列子中,这个查询应预先配置在MovieMapper.xml中,例如:

    2.1K20

    SQL命令 INSERT(一)

    如果只希望禁用外键引用完整性检查,请使用$SYSTEM.SQL.SetFilerRefIntegrity()方法,而不是指定%NOCHECK。...或者,可以使用NOCHECK关键字定义外键,这样就永远不会执行外键引用完整性检查。 %NOFPLAN-忽略此操作的冻结计划(如果有);该操作将生成新的查询计划。冻结的计划将保留,但不会使用。...表参数 可以指定要直接插入到表中的表参数、通过视图插入的表参数或通过子查询插入的表参数。如创建视图中所述,通过视图插入受要求和限制的约束。...赋值 本节介绍如何在INSERT操作期间将数据值分配给列(字段): 值赋值语法描述将数据值指定为列(字段)的文字的各种语法选项。...RowID列不能由用户指定,因此不包括在此语法中。 默认情况下,不能使用此语法填充具有定义的标识字段或RowVersion字段的表。

    6K20

    SQL:函数以及约束

    ,所以id不为空,而且是唯一的;下面我们来看看表; 自增的作用就是会自动的根据序列递增式的填充; 注意:如果我们插入失败了一个行数据,虽然没有插入成功,但是已经向数据库申请到了空间,下次插入的时候自增约束的字段并不会按照表格中现有的数据挨着填充...,格式与where的格式相同; 3>外键(foreign key (从表字段) reference (主表)(主表字段)) 外键:外键是用来让两张表的数据建立联系,从而保证数据的一致性和完整性; 以这两张表为例...; 现在创建员工表: 在没有使用外键之前,尽管两张表在逻辑上有联系,但是在物理上是没有关系的,也就是说我更改部门表中的id员工表没有任何反应,我在员工表中填一个不存在的一个部门id也不会报错; 1...>添加外键 使用语句: 外键添加后会在字段前出现一个蓝色的小钥匙标志 ; 2>检验是否两个表建立了联系 现在我删除掉部门表中的id为1的部门,在员工表中有好多行的员工在该部门,删除后如果报错了说明两个表之间建立了联系...,如果没有报错说明两个表之阿金仍然没有建立物理上的联系; 我删除执行会出现一条报错语句,说明外键发挥了作用;不可以删除或更新主表数据;因为这样会影响到从表的很多数据都需要改变; 下面我们来说说外键的删除和更新行为

    3500

    Mysql - 数据库面试题打卡第四天

    31、MySQL 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之 间的区别?...33、主键和候选键有什么区别? 表格的每一行都由主键唯一标识,一个表只有一个主键。 主键也是候选键。按照惯例,候选键可以被指定为主键,并且可以用于任何外键 引用。...在 MyISAM Static 上的所有字段有固定宽度。动态 MyISAM Dynamic 表将具有像 TEXT,BLOB 等字段,以适应 不同长度的数据类型。...每当行被更改时,时间戳字段将获取当前时间戳。 列设置为 AUTO INCREMENT 时,如果在表中达到最大值,会发生什么情况? 它会停止递增,任何进一步的插入都将产生错误,因为密钥已被使用。...%对应于 0 个或更多字符,_只是 LIKE 语句中的一个字符 如何在 Unix 和 MySQL 时间戳之间进行转换?

    1.2K30

    【重学MySQL】四、关系型数据库设计规则

    数据的完整性:记录中的数据应满足业务逻辑的要求,如非空约束、唯一约束、检查约束等。这些约束有助于确保数据的准确性和可靠性。 字段设计规则 字段命名:字段名应具有描述性,能够反映字段所存储的数据内容。...非空约束:对于不允许为空的字段,应设置非空约束。这有助于确保数据的完整性和准确性。 默认值:对于某些字段,可以设置默认值。这有助于在插入新记录时自动填充某些字段的值,减少数据录入的工作量。...这样,员工表就通过“上级员工ID”字段实现了自我引用。 实现关联关系的要点 主键与外键:在建立关联关系时,通常将一个表的主键作为另一个表的外键。...外键是一个指向另一个表中主键的列,用于建立两个表之间的关系。 唯一性:在一对一关系中,外键列通常具有唯一性约束,以确保每个外键值只能与另一个表中的一条记录相对应。...而在一对多关系中,外键列则不需要唯一性约束,因为多个记录可以具有相同的外键值(即指向同一个主键值)。 索引:为了提高查询效率,通常会为外键列创建索引。

    8510

    【MySQL】:约束全解析

    本文将深入介绍MySQL中的各种约束类型及其使用方法,包括非空约束、唯一约束、主键约束、默认约束、检查约束和外键约束,以及如何在创建表和修改表时添加约束,以及外键约束的相关知识。 一....(与 NO ACTION 一致) 默认行为 CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则 也删除/更新外键在子表中的记录。...SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表 中该外键值为null(这就要求该外键允许取null)。...(外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE; ️全篇总结 本文详细介绍了MySQL中的各种约束类型及其语法,包括约束的概念...通过学习本文,读者可以掌握如何在数据库设计和管理中灵活运用约束,从而保证数据的完整性和准确性,提高数据库的稳定性和安全性。

    28310

    PowerDesigner 的常用方法(转)

    修改外键命名规则 选择Database—>Edit Current DBMS 选择Scripts-》Objects-》Reference-》ConstName 可以发现右侧的Value为: FK...添加外键 Model -> References新建一条外键后,双击进入外键属性,在“Joins”卡片中可以选择子表的外键字段 如何实现Name和code不自动相等 如何实现在CDM中创建Entity...2 如何在PowerDesigner 下建自增列 3 如何在PowerDesigner 下检查设计模型   1 如何在PowerDesigner下建索引   1 双击表设计图,出来Table Properties...,在Tab 页中选择 Indexes   2 单击新建索引的属性,出现Indexex Properties   3 增加一个索引包含的字段   2 如何在PowerDesigner 下建自增列  2...使用SqlServer 数据库中的下列语句来完成 建表语句中,在要做为自增列的字段中,加上如下 IDENTITY(1,1) 还有可以使用下面语句,重置自增种子 dbcc checkident(ConfigSys

    1.1K30

    Spring Boot整合MyBatis Plus实现基本CRUD与高级功能

    本文将详细介绍如何在Spring Boot项目中整合MyBatis Plus,并展示其基本CRUD功能以及高级功能的实现方式。 2....使用了@TableName注解指定了对应的数据库表名,@TableId表示主键,@TableField用于自动填充,@TableLogic表示逻辑删除字段。...createTime字段在插入时自动填充,updateTime字段在插入和更新时自动填充。...拓展:MyBatis Plus的其他功能 除了上述介绍的功能外,MyBatis Plus还提供了许多其他强大的功能,如条件构造器、分页查询、性能分析、多租户支持等。...总结 通过本文的介绍,我们学习了如何在Spring Boot项目中整合MyBatis Plus,并实现了基本的CRUD功能以及高级功能如自动填充、乐观锁、逻辑删除等。

    20800

    MySQL基础之函数【字符串,数值,日期,流程】和约束

    而在数据库中,存储的都是入职日期,如 2000-11-12,那如果快速计算出天数呢? 2、在做报表这类的业务需求中,我们要展示出学员的分数等级分布。...而在数据库中,存储的是学生的分数值,如98/75,如何快速判定分数的等级呢? 其实,上述的这一类的需求呢,我们通过MySQL中的函数都可以很方便的实现 。...2.2.1 语法 1、添加外键 CREATE TABLE 表名( 字段名 数据类型, ......FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) ; 案例: 为emp表的dept_id字段添加外键约束,关联dept表的主键id。...具体的删除/更新行为有以下几种:  具体语法为: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名

    1K30

    N天爆肝数据库——MySQL(3)

    默认约束:DEFAULT 保存数据时,如果未指定该字段的值,则采用默认值 检查约束:CHECK 保证字段值满足某一个条件 外键约束:FOREIGN KEY 用来让两张表的数据之间建立连接,保证数据的一致性...和完整性 外键约束: 概念 外键用来让两张表中的数据之间建立连接,从而保证数据的一致性和完整性。...语法: 添加外键 CREATE TABLE 表名( 字段名 数据类型, ......[CONSTRAINT][外键名称]FOREIGN(外键字段名)REFERENCES 主表(主表列名) ); ALTER TABLE 表名ADD CONSTRAINT 外键名称 FOREING KEY...(外键字段名) REFERENCES 主表(主表列名); 删除外键 ALTER TABLE 表名DROP FOREIGN KEY 外键名称; 删除/更新行为 NO ACTION RESTRICT CASCADE

    18720
    领券