使用自关联方法处理多表关系

使用自关联方法处理多表关系

这里通过省市区之间的关系来解释自关联的情况

在设置地址的过程中 , 不可避免的需要设置 , 省份 ,市以及区

而省市区三者之间的具有一定的关联关系

一个省份对应多个市

一个市对应多个区

如果通过设置主表从表关系则需要设置三张标分别对应省市区 , 这对数据处查询造成了很大的压力

所以我们在这里使用自关联的方法使用一张表来解决上述问题

# 自关联
# id   name   -id
#  1  广东省   null
#  2  湖北省
#  3  广州市    1
#  4  天河区    3

如上述 , 广州市为广东省的一个市 , 则可以为其设置一个外键 , 外键的值与广东省即主键相同

同理天河区为广州市的一个区 , 我们也可以按上述方法进行设置

这样我们在调用查询的过程中就可以通过从键获得省市区之间的对应关系

在Django中的ORM数据库框架如何设置自关联

class Area(models.Model):
    name = models.CharField(max_length=20)
    # 自关联 : self
    # SET_NULL: 删除被关联的数据 , 对应链接的数据字段值会设置为 NULL
    parent = models.ForeignKey('self' , on_delete=models.SET_NULL , null=True,blank=True,related_name='subs')
    
    class Meta:
        db_table = 'areas'

在Django的模型(models)定义中,ForeignKey 是一个用于表示两个模型之间一对多关系的字段。在你给出的代码片段中,ForeignKey 被用于一个模型自身,即所谓的“自引用”或“递归”关系。让我们逐一分析该字段的各个参数:

python复制代码

parent = models.ForeignKey('self', on_delete=models.SET_NULL, null=True, blank=True, related_name='subs')
  1. ‘self’
    • 这表示ForeignKey指向的是同一个模型(即该模型自身)。在数据库中,这意味着该表会有一个外键字段,该字段引用该表的另一个记录。
  2. on_delete=models.SET_NULL
    • 当被引用的对象(即父对象)被删除时,该字段的值将被设置为NULL。这是Django提供的一种处理外键对象删除时的策略。
    • 注意:为了使用SET_NULL,相应的字段(在这个例子中是parent)必须允许NULL值,这就是为什么null=True也被设置的原因。
  3. null=True
    • 这表示该字段在数据库中可以为NULL。由于这是一个ForeignKey,当没有关联的父对象时,这个字段可能会是NULL
  4. blank=True
    • 在Django的表单验证中,blank=True表示该字段在表单中可以为空(即用户可以不填写该字段)。但是,对于ForeignKey字段,blank通常与表单的验证相关,而不是数据库层面的。在数据库层面,它是否可以为空是由null参数决定的。但在Django的admin或自定义表单中,你可能会想允许用户不填写这个字段,这时blank=True就很有用了。
  5. related_name=‘subs’
    • 这为反向关系提供了一个名字。默认情况下,如果你有一个名为MyModel的模型,并且它有一个指向自身的ForeignKey,那么你可以通过my_model_instance.mymodel_set.all()来获取与该实例相关的所有子对象。但是,通过设置related_name='subs',你可以通过my_model_instance.subs.all()来获取这些子对象,这使得代码更加清晰和易读。

综上所述,这个ForeignKey字段定义了一个模型与其自身之间的递归关系,允许模型实例有一个父实例(或没有),并提供了在父实例被删除时如何处理该关系的策略。同时,它还为反向关系提供了一个易于理解和使用的名字。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/605752.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

cypress的安装使用

cypress npm install -g cnpm --registryhttps://registry.npm.taobao.org

力扣41. 缺失的第一个正数

Problem: 41. 缺失的第一个正数 文章目录 题目描述思路复杂度Code 题目描述 思路 1.将nums看作为一个哈希表,每次我们将数字n移动到nums[n - 1]的位置(例如数字1应该存在nums[0]处…),则在实际的代码操作中应该判断nums[i]与nums[nums[i] - 1]是否相等,若…

直播报名 | 珈和科技携手潍柴雷沃共探“现代农场”未来式

数据赋农季系列直播第四期,我们将以“未来农业发展趋势之农场智慧化、管理数据化”为主题展开,此次系列直播由珈和科技及湖北珞珈实验室共同主办,第四期直播很荣幸邀请到潍柴雷沃参与其中,双方将就智慧农服平台和数据交易SaaS平台…

交友软件源码-源码+搭建+售后,上线即可运营聊天交友源码 专业语聊交友app开发+源码搭建-快速上线

交友小程序源码是一种可以帮助开发者快速搭建交友类小程序的代码模板。它通常包括用户注册、登录、个人信息编辑、匹配推荐、好友聊天等常见功能,以及与后台数据交互的接口。使用这种源码可以极大地缩短开发时间,同时也可以根据自己的需求进行二次开发和…

Docker与Harbor:构建企业级私有Docker镜像仓库

目录 引言 一、本地私有仓库 (一)基本概述 (二)搭建本地私有仓库 1.下载registry镜像 2.启动容器 3.上传本地镜像 4.客户端下载镜像 二、Harbor简介 (一)什么是 Harbor (二&#xff…

优质资料:大型制造企业等级保护安全建设整改依据,系统现状分析,网络安全风险分析

第1章 项目概述 XX 大型制造型企业是国内一家大型从事制造型出口贸易的大型综合企业集团,为了落实国家及集团的信息安全等级保护制度,提高信息系统的安全防护水平,细化各项信息网络安全工作措施,提升网络与信息系统工作的效率&am…

123.Android 简单的定位和语音识别 免费高德定位 免费语音识别 不需要接入SDK 不需要导入任何的离线包

//免费的定位 高德定位 不需要接入高德SDk也可进行高德定位: //免费的语音识别 不需要接入任何的SDK 也不需要导入任何的离线语音包: //CSDN 小妞得意 //具体代码实现 私聊 //---------------------------------------------------------------END…

驱动比例线圈功率放大器

驱动比例线圈功率放大器是一种用于控制比例电磁铁的电流大小实现被控设备的位移,采用高性能的嵌入式32位微处理器作为运算核心,这些微处理器具有高速指令运行能力,电源24VDC驱动,输入指令兼容性强,输出电流大小可调&am…

首席数据官CCRC-CDO如何构筑企业数据合规的坚固防线

在当今信息化快速发展的时代,数据已经成为企业最宝贵的资产之一。然而,随着数据规模的迅速增长,数据合规问题也日益凸显。首席数据官(CDO)作为企业中负责数据战略和管理的核心人物,构筑企业数据合规的坚固防…

社区奶柜:小本创业,大有可为

社区奶柜:小本创业,大有可为 在快节奏的现代生活中,人们对健康、便捷生活方式的追求日益增长。社区奶柜加盟项目,正是应运而生,它不仅满足了居民对于新鲜、营养乳制品的日常需求,也为寻求创业机会的您铺设…

Linux系统(CentOS)下安装配置 Nginx 超详细图文教程

一、下载并安装 1.打开nginx官网并点击右侧的download,Nginx官网下载地址 2.选择稳定版本 我放在/usr/local/nginx/下,新建文件夹 mkdir /usr/local/nginx/ 通过xftp传输到Linux的服务器上,这里方法不过多复述。 或者如果Linux联网&#xf…

gpt_academic的使用——含一键安装和接入其他API以及本地模型

https://github.com/binary-husky/gpt_academic/releases/ https://github.com/binary-husky/gpt_academic/wiki 安装

Github的使用教程(下载项目、寻找开源项目和上传项目)

根据『教程』一看就懂!Github基础教程_哔哩哔哩_bilibili 整理。 1.项目下载 1)直接登录到源码链接页或者通过如下图的搜索 通过编程语言对搜索结果进一步筛选。 如何去找开源项目:(Github 新手够用指南 | 全程演示&个人找项目技巧放…

智慧公厕:打造智能、安全、舒适的公共厕所新时代

随着智慧城市建设的不断推进,公共设施的智能化也已成为一种必然趋势。在这一背景下,智慧公厕作为城市管理的一个重要方面,正逐渐走进人们的视野。通过对所在辖区内所有公共厕所的全域感知、全网协同、全业务融合以及全场景智慧的赋能&#xf…

数据库中索引的底层原理和SQL优化

文章目录 关于索引B 树的特点MySQL 为什么使用 B 树? 索引分类聚簇索引 和 非聚簇索引覆盖索引索引的最左匹配原则索引与NULL索引的代价大表结构修改 SQL优化EXPLAIN命令选择索引列其它细节 关于索引 索引是一种用来加快查找效率的数据结构,可以简单粗暴…

[C++] 类和对象:运算符重载

前言: 在C中,运算符重载是一种强大的特性,它允许我们重新定义已有的运算符,以便用于用户自定义的数据类型。通过运算符重载,我们可以使得我们自定义的类对象像内置类型一样进行运算,这为编写清晰、简洁且易…

Redis(安装及配置)

1.什么是redis Redis 全称 Remote Dictionary Server(即远程字典服务),它是一个基于内存实现的键值型非关系(NoSQL)数据库,由意大利人 Salvatore Sanfilippo 使用 C 语言编写。 2.优势 性能极高&#xff…

靠谱二次元行研组:2024年国产动画番剧趋势报告

靠谱二次元行研组 根据靠谱二次元(公众号ID:kpACGN)统计,2023年全年累计在播动画番 剧超140部,有更新的年番超过15部。其中有123部国产动画番剧新开播,涉 及110个IP,80家制作公司,新…

Cloudera的简介及安装部署

简介 Cloudera是一家位于美国的软件公司,成立于2008年,专注于为企业客户提供基于Apache Hadoop的软件、支持、服务以及培训。Cloudera的开源Apache Hadoop发行版,即Cloudera Distribution including Apache Hadoop(CDH&am…

基于YOLOv5的火焰目标检测(代码+数据集+训练好的模型)

基于YOLOv5的火焰目标检测项目是一个旨在实时识别和定位视频或图像中火焰区域的计算机视觉应用。YOLOv5是YOLO(You Only Look Once)系列目标检测模型的一个高效版本,以其快速、准确且易于部署的特点而受到青睐。 技术背景 YOLOv5&#xff1…
最新文章