多对一关系
在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:
- CASCADE级联,删除主表数据时连通一起删除外键表中数据
- PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据
- SET_NULL设置为NULL,仅在该字段null=True允许为null时可用
- SET_DEFAULT设置为默认值,仅在该字段设置了默认值时可用
代码:
准备人物列表信息的模型类
class PeopleInfo(models.Model):
GENDER_CHOICES = (
(0, ‘male’),
(1, ‘female’)
)
name = models.CharField(max_length=20, verbose_name=‘名称’)
gender = models.SmallIntegerField(choices=GENDER_CHOICES, default=0, verbose_name=‘性别’)
description = models.CharField(max_length=200, null=True, verbose_name=‘描述信息’)
book = models.ForeignKey(BookInfo, on_delete=models.CASCADE