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
字段还接受许多别的参数,在模型字段参考有详细介绍。 这些选项有助于确定关系如何工作;都是可选的。
访问反向关联对象的细节,请见反向查询关联关系的示例。
示例代码,请见多对一关联关系示例。