sqlite 表与表之间的关系_第33章 Django多表关系之一对一

再次见到多表关系,心中不免又泛起了涟漪,之前没讲清楚的内容,终于有机会得以补充。表与表之间的三种关系再次提上议程,在model中的属性重现江湖。

035f519312704c9e0c068da3488179e7.png

多表关系,涉及到级联操作,在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纵向布局,页面效果挺好的,你喜欢不?如果不喜欢的话,可以找我,但是我也没办法。

165650171466ef4a744108bf35c59364.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值