django_models_关系一对多

关系数据库

  关系数据库的威力体现在表之间的相互关联。 Django 提供了三种最常见的数据库关系:多对一(many-to-one),多对多(many-to-many),一对一(one-to-one)。

多对一关系 

  Django 使用 django.db.models.ForeignKey 定义多对一关系。 和使用其它Field类型一样:在模型当中把它做为一个类属性包含进来。

  ForeignKey 需要一个位置参数:与该模型关联的类。

  比如,一辆Car有一个Manufacturer — 但是一个Manufacturer 生产很多汽车(Car),每一辆Car 只能有一个Manufacturer — 使用下面的定义:

from django.db import models

class Manufacturer(models.Model):
    # ...
    pass

class Car(models.Model):
    manufacturer = models.ForeignKey(Manufacturer, on_delete=models.CASCADE)
    # ...

你还可以创建递归关联关系(与自身具有多对一关系的对象)和与尚未定义的模型的关系;有关详细信息,请参见模型字段参考

建议你用被关联的模型的小写名称做为ForeignKey 字段的名字(例如,上面manufacturer)。 当然,你也可以起别的名字。 例如:

class Car(models.Model):
    company_that_makes_it = models.ForeignKey(
        Manufacturer,
        on_delete=models.CASCADE,
    )
    # ...

注意:

  在模型类中,一对多,外检模型定义在多的一方。 ForeignKey 字段

提示:

  ForeignKey 字段还接受许多别的参数,在模型字段参考有详细介绍。 这些选项有助于确定关系如何工作;都是可选的。

       访问反向关联对象的细节,请见反向查询关联关系的示例

       示例代码,请见多对一关联关系示例

原文地址:https://www.cnblogs.com/Xingtxx/p/11009881.html