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

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

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

  • 相关阅读:
    排座椅
    关于math.h的问题
    客户调查
    排队打水
    删数游戏
    小数背包
    零件分组
    桐桐的组合
    桐桐的数学游戏
    桐桐的全排列
  • 原文地址:https://www.cnblogs.com/Xingtxx/p/11009881.html
Copyright © 2020-2023  润新知