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

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

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

10610

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

1. django中的常用字段 1. AutoField 映射到数据库中是int类型,可以有自动增长的特性。一般不需要使用这个类型,如果不指定主键,那么模型会自动的生成一个叫做id的自动增长的主键。...外键和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。...因此这里我们首先来介绍下外键在Django中的使用。 类定义为class ForeignKey(to,on_delete,**options)。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。

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

    SpringBoot返回枚举对象中的所有属性以对象的形式返回(一个@JSONType解决)

    一、前言 最近小编在开发中遇到个问题,就是关于枚举方面的使用。一些固定不变的数据我们可以通过枚举来定义,减少对数据库的查询。是一种常见的开发技巧!...常见场景的需求是:通过某一个属性获取对应的枚举属性的另一个值;还有就是常量枚举,比如一下统一返回状态和编码! ==小编的需求是把枚举中的所有属性都取出来,转成实体类那种返回给前端!...== 最简单的解决就是拿到所有的然后便利加到新的集合里,这样还需要定义一个实体类来接收转一下!...这样有点麻烦,小编也是无意发现了,项目中有以前大佬留下来的一个注解@JSONType(serializeEnumAsJavaBean = true),一加上只需要我们使用枚举.values()即可直接帮助我们返回了..."秋" }, { "code": "004", "name": "冬" } ] 六、总结 这样就完美完成枚举转实体类了,而且还没有新增实体类,一个注解解决哈

    3.9K10

    【Django 2.2文档系列】Model 外键中的on_delete参数用法

    场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束的行为,在删除此条数据时,同事删除外键关联的对象。...比如:用户的有一个外键关联的是用户的健康记录表,当用户删除时,配置了这个参数的健康记录表中跟这个用户有关的数据也会被删除。...” models.PROTECT 防止删除引用的对象。与上个恰恰相反,是防止关联数据被删除。 models.SET_NULL 设置关联的外键内容为null。只有设置了null=True时可用。...models.SET()将SET()设置的值作为外键的值 ,如果传递了callable,则调用它的结果。 DO_NOTHING不采取行动。

    2K10

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

    Django中基表的设置 通过图书管理系统引入多表操作:如果我们创建表的方式是先抽象出表与表之间相同的字段建一个父类,然后在用每个表类去继承这个父类,如下面的代码,我们将无法得到期望的表字段。...db_table = 'xxx'指定该类的数据库表单名字。当然如果不指定也没关系,Django会自动默认的按照一定规则生成数据模型对应的数据库表名。...更合理) """ Django orm中外键字段属性详解 在建表之前我们对外键字段属性进行了解: 1)related_name在外键中设置外键反向查询的字段名:正向找字段名,反向找related_name...例子:部门没有了,部门员工里的部门字段改为未分组部门的id字段为NULL 注:多对多字段不能设置on_delete级联关系,如果要处理级联关系,需要手动明确关系,处理表关系中的多个外键 3)db_constraint...子序列化的使用方法及注意事项: 1)只能在序列化中使用 2)字段名必须是外键(正向反向都可以)字段,相对于自定义序列化外键字段,自定义序列化字段不能参与反序列化,而子序列化必须为外键名,子序列化字段不写入数据库

    4.3K30

    Django之ORM

    表示多对多的关系。 除了这种方式也可以手动创建一个表,手动添加两个外键来实现多对多。...,values返回的是一个字典序列 count(): 返回数据库中匹配查询(QuerySet)的对象数量。...2.QuerySet对象 查询的结果集就是一个QuerySet对象 QuerySet对象就像是一个列表,列表存储着查询出的结果,可以迭代,可以切片 Django中QuerySet对象是惰性的,即你得到这个对象的时候并没有真正的在数据库中执行...使用’__’进行的查找 一对多 school_name为外键对象的字段 school为student表中设置的外键字段 student1=student.objects.filter(id=2).values...不区分大小写 等等 5.聚合查询aggregate 聚合查询是对QuerySet对象进行计算得到一个结果值作为字典中的值放到一个字典中 这里先引入一些聚合方法 from django.db.models

    1.1K30

    从 Django 模型中根据类查找外键

    例如,在 Book 模型中,外键可能叫做 author_id, 而在 Article 模型中,外键可能叫做 author.我们希望有一个方法可以根据外键的类来检索外键对象,无论外键的名称是什么。...我们还可以在模型类中定义一个 get_foreign_key_to() 方法,该方法返回指向给定类的外键字段。...该方法返回了指向 Author 模型的外键字段,并将其存储在 author_foreign_key 变量中。问题背景Foo 有很多可以从 Django 模型引用的外键,但我希望使用通用方法来获取对象。...django.db.models import ForeignKey​def get_foo(model): """返回指向 Foo 对象的外键。​...get_foo() 函数,该函数接受一个 Django 模型作为参数并返回指向 Foo 对象的外键。

    8810

    django 外键引用自身和on_delete参数

    如果外键对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。如果我们强行删除,Django就会报错。...如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,== 前提是要指定这个字段一个默认值 ==。 SET():如果外键的那条数据被删除了。...那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。...、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null; 为什么在django中可以是用不同的约束去操作数据库呢。...比如 django 中 on_delete=CASCADE, 但是数据库的外键约束是RESTRICT.

    1.4K20

    Django ORM 多表操作

    ORM 多表操作 表模型 图书表 出版社表 作者表 作者详情表 表关系 一对一:一对一推荐建在查询频率高的一方 一对多:外键字段建在多的一方 多对多:外键字段建在查询频率多的一方,在Django第三张表不需要创建...,自动创建 ps:外键字段不需要写表名_id后面的_id,ORM创建的时候自动添加了_id,以及外键以虚拟字段的形式存在 创建模型 '''models.py''' from django.db import...添加数据(添加外键) 一对多(外键 ForeignKey) 方式一: 传对象的形式,返回值的数据类型是对象,书籍对象 步骤: 获取出版社对象 给书籍的出版社属性 pulish 传出版社对象 '''test.py...id 的形式(常用) 一对多中,设置外键属性的类(多的表)中,MySQL 中显示的字段名是:外键属性名_id。...口诀: 正向查询按外键字段 反向查询按表名小写 注意: 正向:属性名 反向:小写类名加 _set 反向查询的时候查询的对象可能有多个的情况加__set,查询的对象只有一个的情况不需要加 基于对象的跨表查询

    1.8K20

    Django中ORM操作

    1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...,则自动会创建一个列名为id的列 from django.db import models class UserInfo(models.Model):...(self, connection): return 'integer UNSIGNED' PS: 返回值为字段在数据库中的属性,Django字段默认的值为...,ForeignKey字段就建在子表; 如果B表的1条记录也对应A表中N条记录,两表之间就是双向1对多关系,也称为多对多关系; 在orm中设置如果 A表设置了外键字段user=models.ForeignKey...().first() result = obj.userinfo_set.all() [userinfo对象,userinfo对象,] 小写的表名 得到有外键关系的列 #因为使用values取值取得是字典的不是对象

    4.8K10

    Django框架学习(三)

    (request,'模板文件名',) render返回的是一个响应的对象。...render 其实就是就是下面模板的详细步骤的一个简写封装。 3.3模板的详细步骤(重点掌握) 如果我们不想返回响应对象,只是想渲染一下页面,替换数据,那么我们可以按下面的来。...| 过滤器(参数...)}} b) Django中模板过滤器的使用: {{ 模板变量 | 过滤器:参数 }} 注意:Django中过滤器:号之后只能接收一个参数 ?...AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理...,在django.db.models中包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外键表中数据 PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据

    1.8K40

    Django 多数据库配置与使用总结

    /download/2.0.13/tarball/ #需求描述 项目开发中,部分业务功能的实现,需要跨数据库查询,并且想通过Django自带ORM来实现 #解决方案 为Django配置多数据库,具体操作步骤如下...#该名称可自定义 'ENGINE': 'django.db.backends.mysql', 'NAME': 'second_db_name', 'USER...return None def allow_relation(self, obj1, obj2, **hints): """控制是否允许obj1和obj2建立关联关系,供外键和多对多操作使用...,如果返回True则表示允许,如果返回False则阻止建立关联关系,如果返回None则表示仅允许在相同数据库内的对象建立关联关系(备注:笔者亲测,执行save()保存包含关联外键对象,或者通过某个对象获取关联外键对象...,考虑是否为model指定app_label,如果不指定,在默认数据库上执行相关操作。

    2.8K20

    Django相关知识点回顾

    Flask中request请求对象的属性 Django中request请求对象的属性 说明 args GET 查询字符串参数 form POST 请求体中的表单数据 data body 请求体中的原始...class Meta: db_table = '' 定义外键属性: # 表中外键字段名格式: 外键属性_id> hbook = models.ForeignKey('BookInfo...= 值 可以写多个查询条件,默认是且的关系 F对象: 用于查询时字段之间的比较 from django.db.models import F Q对象: 用于查询时条件之间的逻辑关系 from django.db.models...() # 由多查1 多对象.外键属性 例:hero.hbook 2.通过模型类进行关联查询 # 查图书(一) 一类.objects.get|filter(多类名__字段__条件=值) 例:books =...注意:对于QuerySet类的对象,可以继续调用之前所讲任何一个查询函数。

    10K51

    django 1.8 官方文档翻译: 2-5-6 多数据库

    这是纯粹的验证操作,外键和多对多操作使用它来决定两个对象之间是否应该允许一个关联。...这个方法还可以用来决定一个给定数据库上某个模型的可用性。 注意,如果这个方法返回False,迁移将默默地不会在模型上做任何操作。这可能导致你应用某些操作之后出现损坏的外键、表多余或者缺失。...目前不提供跨多个数据库的外键或多对多关系的支持。...如果你使用一个路由来路由分离到不同的数据库上,这些模型定义的任何外键和多对多关联必须在单个数据库的内部。 这是因为引用完整性的原因。...然而,如果你正在使用SQLite 或MySQL的MyISAM 表,则没有强制性的引用完整性;结果是你可以‘伪造’跨数据库的外键。但是Django 官方不支持这种配置。

    1.5K20

    Django模型

    下面是Django中常用的字段类型的详情 字段类型 类型 说明 BigAutoField 自动增长的BigIntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性...外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...下面是另外一个模型,和前面的BookInfo模型通过外键关联起来。...外键:通过使用models.ForeignKey来设置外键,ForeignKey的第一个参数是要关联的模型类名,第二个参数是on_delete。...设置外键的时候需要制定另一张表中关联的字段,但是在Django里并没有指定。

    1.9K20

    Django之ForeignKey和ManyToManyField多表查询

    只有在db_constraint=True时Django model才会在数据库上建立外键约束, 在该值为False时不建立约束. 默认db_constraint=True....ForeignKey.related_name 这个名称用于让关联的对象反查到源对象. 如果你不想让Django 创建一个反向关联,请设置related_name 为 '+' 或者以'+' 结尾....ManyToManyField.through_fields 上文示例中Membership 有两个外键指向Person (person 和inviter),这使得关联关系含混不清并让Django 不知道使用哪一个...在这种情况下,必须使用through_fields 明确指定Django 应该使用哪些外键 through_fields 接收一个二元组('field1', 'field2'),其中field1 为指向定义...ManyToManyField 字段的模型的外键名称(本例中为group),field2 为指向目标模型的外键的名称(本例中为person).

    1.8K10

    【Django】Django ORM 学习笔记

    Manager 在创建完 Model 对象之后,Django 会自动为其关联一个 Manager 对象,该对象是 Model 进行数据库操作的接口。...关联查询就是在查询当前实例的同时,把其关联的实例数据也一块取出来。在下图中 orm_blog 通过一个外键和 orm_author 关联。...关联大体上可以分为两种: 只有一个关联实例: 外键关联中包含外键的表、OneToOneField,例如下图中的 orm_blog 只与一个 orm_author 的实例关联 有多个关联实例:外键关联中不含外键的表...`id` ASC LIMIT 1 select_related 会沿着外键递归查询,例如上图中取表 1 的实例时,会沿着外键将表 3 的数据一块取出来。...aggregate: 针对所有记录调用聚合函数,返回一个 dict 对象,下面是使用示例: from django.db.models import Min from django.db.models

    2.2K20
    领券