再次见到多表关系,心中不免又泛起了涟漪,之前没讲清楚的内容,终于有机会得以补充。表与表之间的三种关系再次提上议程,在model中的属性重现江湖。
多表关系,涉及到级联操作,在OneToOneField和ForeignKey中有个on_delete选项(ManyToManyField没有),其可选值有:
models.CASCADE: 关联表中的数据删除时,该外键也被删除(级联删除);
models.SET_NULL: 关联表中的数据删除时,外键置为空(前提是这个外键字段是
null=True);
models.SET_DEFAULT: 删除的时候,外键字段置为默认值(前提是外键有指定默认值) ;
PROTECT: 保护模式,如果采用该选项,删除的时候,会抛出ProtectedError错误;
SET(): 自定义一个值,该值只能是对应的实体。
33.1 一对一关系
在企业里工作,你知道每个月哪天最开心么?—没错,发工资那天。一般企业发工资都是让银行代扣款,转进指定的银行卡里。银行卡跟个人是一对一的关系。
新建的Model放在Post或Department应用下都可以,我选Department,你随意。对了,有个价值百万的操作,千万不要忘记了,记得通过命令生成数据表。
from django.db import modelsimport django.utils.timezone as timezone# 银行卡基本信息class Card(models.Model): card_num = models.CharField(max_length=30, verbose_name="卡号") name = models.CharField(max_length=60, verbose_name="姓名") ID_card = models.CharField(max_length=20, verbose_name='身份证') createDate = models.DateField(default=timezone.now, verbose_name='创建日期') class Meta: verbose_name_plural = '银行卡账户' verbose_name = "银行卡账户" def __str__(self): return self.card_num# 银行卡详情信息class CardDetail(models.Model):# 一对一关联,属性可以定义在任意一方 card = models.OneToOneField(Card, on_delete=models.CASCADE, verbose_name='卡号') tel = models.CharField(max_length=30, verbose_name="电话") mail = models.CharField(max_length=30, verbose_name="邮箱") city = models.CharField(max_length=10, verbose_name="城市") address = models.CharField(max_length=30, verbose_name="详细地址") class Meta: verbose_name_plural = '个人详细资料' verbose_name = "个人详细资料"
有了Card Model,还需要创建CardAdmin,那样才可以加入到后台管理系统中。
from django.contrib import adminfrom .models import Card, CardDetail, Department, Resume, Experience# 纵向显示用:StackedInlineclass CardDetailAdmin(admin.StackedInline): model = CardDetail@admin.register(Card)class ControlCard(admin.ModelAdmin): list_display = ("card_num", "name", "ID_card", 'createDate') # 日期在添加/修改不显示,用默认值 exclude = ['createDate'] # 在Card页面显示详细信息CardDetail inlines = [CardDetailAdmin]
一对一通过StackedInline纵向布局,页面效果挺好的,你喜欢不?如果不喜欢的话,可以找我,但是我也没办法。