Django模型继承之多表继承

在Django模型继承中,支持的第二种模型继承方式是层次结构中的每个模型都是一个单独的模型。每个模型都指向分离的数据表,并且可以被独立查询和创建。在继承关系中,子类和父类之间通过一个自动创建的OneToOneField进行连接。示例代码如下:

【代码3-20】

复制代码
01  from django.db import models
02  
03  class Place(models.Model):
04      name = models.CharField(max_length=50)
05      address = models.CharField(max_length=80)
06  
07  class Hotel(Place):
08      roomA = models.BooleanField(default=False)
09      roomB = models.BooleanField(default=False)
10      roomC = models.BooleanField(default=False)
11      #...
12      pass

【代码分析】

在第03~05行代码中,定义了一个用于表示地点的抽象基类Place。其中,第04行和第05行代码定义了两个属性name和address,分别用于表示名字和地址。

在第07~10行代码中,定义了一个继承自抽象基类Place的、用于表示酒店的子类Hotel。其中,第08~10行代码定义了3个属性roomA、roomB和roomC,分别用于表示3种酒店房间类型。

另外根据继承规则,抽象基类Place的所有属性在子类Hotel中也均是可以使用的。

因此,基于【代码3-20】的模型设计,可以进行如下操作:

  • >>> Place.objects.filter(name="King's Place")
  • >>> Hotel.objects.filter(name="King's Place ")

假如一个Place对象同时也是Hotel对象,就可以通过小写的模型名将Place对象转换为Hotel对象,示例代码如下:

  • >>> p = Place.objects.get(id=10)
  • If p is a Hotel object, this will give the child class:

  • >>> p.hotel
  • <Hotel:...>

在上述例子中,如果p不是一个Hotel对象,而仅仅是一个Place对象(又或是其他类的父类对象),那么指向p.hotel就会抛出一个Hotel.DoesNotExist类型的异常。

在Hotel模型中自动创建的、连接至Place模型的OneToOneField看起来类似下面的代码:

【代码3-21】

复制代码
01  place_ptr = models.OneToOneField(
02      Place, on_delete=models.CASCADE,
03      parent_link=True,
04  )

【代码分析】

设计时可以在Hotel中通过声明自己的OneToOneField,并在其中设置"parent_link=True"属性来重写该字段。

本文节选自《Django 5企业级Web应用开发实战(视频教学版)》,获出版社和作者授权发布。

相关推荐
小Tomkk10 分钟前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台1 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
Python智慧行囊1 小时前
Python 中 Django 中间件:原理、方法与实战应用
python·中间件·架构·django·开发
沉到海底去吧Go2 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局2 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务2 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
一只爱撸猫的程序猿4 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe4 小时前
sql中group by使用场景
数据库·sql·数据挖掘
消失在人海中4 小时前
oracle sql 语句 优化方法
数据库·sql·oracle
Clang's Blog4 小时前
一键搭建 WordPress + MySQL + phpMyAdmin 环境(支持 PHP 版本选择 & 自定义配置)
数据库·mysql·php·wordpr