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

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

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

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

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

一个省份对应多个市

一个市对应多个区

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

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

# 自关联
# 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: 删除被关联的数据 , 对应链接的数据字段值会设置为 NULLparent = 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.mzph.cn/news/833695.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电子书3D翻页制作技巧大揭秘,轻松将文档转化为逼真仿真书!

随着数字化时代的到来,电子书已成为阅读的主流形式之一。然而,普通的电子书往往缺乏纸质书的质感和互动性,让人感到有些遗憾。今天,将为你揭秘电子书3D翻页制作技巧,让你轻松将文档转化为逼真仿真书! 1.要制…

LearnOpenGL(九)之材质

一、材质 在现实世界里,每个物体会对光产生不同的反应。比如,钢制物体看起来通常会比陶土花瓶更闪闪发光,一个木头箱子也不会与一个钢制箱子反射同样程度的光。在opengl中,我们可以针对每种表面定义不同的材质(Material)属性来模…

Mac 解决外接移动硬盘(NTFS格式)无法写入的问题

文章目录 1. 问题描述2. 解决步骤 1. 问题描述 MacOS 可以识别 NTFS 格式的磁盘,但是默认情况下是只读模式,即无法向 NTFS 格式的磁盘写入数据。这是因为 NTFS 是 Windows 系统默认的文件系统格式,而 MacOS 对 NTFS 的写入支持是有限的。 如…

生成式人工智能教学解决方案

一、软件技术人员的需求分析 在当今信息化社会,软件技术作为推动科技创新和经济发展的核心力量,其重要性日益凸显。随着数字化转型的加速推进,各行各业对软件技术人才的需求呈现出多元化、高端化的发展趋势。以下是软件技术人员需求的详细分…

指定地区|CSC高级研究学者赴澳大利亚访学交流

CSC高级研究学者均是正高或博导级的,学术背景较强,多数能DIY联系到国外合作机构。但也有些申请者因指定地域或学校,或须在短期内获取邀请函故而求助于我们。本案例D教授就指定澳大利亚的墨尔本地区,我们最终用维多利亚大学的邀请函…

通达OA SQL注入漏洞【CVE-2023-4166】原理及检测思路分析

1、漏洞描述 通达OA中发现一个漏洞,并被列为严重漏洞。该漏洞影响文件general/system/seal_manage/dianju/delete_log.php的未知代码。对参数 DELETE_STR 的操作会导致 sql 注入。 2、影响范围 通达OA版本11.10之前 3、复现环境 FOFA搜索:app"TDX…

JWK和JWT 学习

JWK和JWT 介绍 JWK (JSON Web Key) 和 JWT (JSON Web Token) 是现代Web应用程序中用于安全通信的两个重要概念。它们都是基于JSON的,并且是OAuth 2.0和OpenID Connect等协议的核心组成部分。 官方文档 JWT官方网站 JWK和JWK Set的RFC文档 JWT的RFC文档 JWK (JS…

Oopsie从80端口到获取root权限的渗透过程

Oopsie 需要用到的工具burpnmapnc手写代码信息收集 由于是靶场的原因单一没有子站所以收集到ip就可以nmap扫描 拿到IP第一件事就是扫描端口 nmap -T4 -sV -sC -sS 10.129.24.79 -T4:提升扫描速度 -sV:查看详细版本 -sC:使用默认类别的脚本进行扫描 可更换其他类别…

用于图像分类的CNN:ImageNet Classification with Deep Convolutional Neural Networks

ImageNet Classification with Deep Convolutional Neural Networks NIPS-Alex Krizhevsky, Ilya Sutskever, Geoffrey E. Hinton-2012 思路 训练了一个大型的深度卷积神经网络,将ImageNet LSVRC-2010竞赛中的120万张高分辨率图像分类为1000个不同的类别。 神经网络有6000万…

使用 Cython 加密 Python 代码防止反编译

文章目录 前言使用 Cython 加密 Python 代码环境Python 源代码编写 Cython 编译配置文件 编译查看输出文件使用 问题error: Microsoft Visual C 14.0 or greater is requiredpyconfig.h(59): fatal error C1083: 无法打开包括文件: “io.h”: No such file or directorydynamic…

Postgresql中JIT函数能否inline的依据function_inlinable

相关 《LLVM的ThinLTO编译优化技术在Postgresql中的应用》 在JIT inline函数的过程中,会通过函数的bc代码,经过一系列规则、成本的判断来决定函数能否Inline,本篇重点分析这段逻辑:function_inlinable。 总结速查: 入…

【python】常见的python下载库镜像源

python中的第三方库大多由国外提供,在国内直接进行下载时,可能会因为访问国外网络较慢,而出现下载超时的报错提醒,为了避免出现类似问题,我们可以在下载库时加入国内的镜像源来下载,这样就不会出现网络较慢…

分布式链路追踪工具Sky walking详解

1,为什么要使用分布式链路追踪工具 随着分布式系统和微服务架构的出现,且伴随着用户量的增加,项目的体量变得十分庞大,一次用户请求会经过多个系统,不同服务之间调用关系十分复杂,一旦一个系统出现错误都可…

Clickhouse中物化视图和位图和索引的用法

目录 聚合函数表引擎AggregatingMergeTree物化视图位图Clickhouse实现数据的有限更新索引 聚合函数 例如 max(val) , argMax(arg,val) 如果在聚合函数后面加入后缀if,则是 maxIf(val,UInt8) argMaxIf(arg,val,UInt8) 也就是当满足某个条件时候,才会对这一行数据进行…

iphone忘记锁屏密码怎么解锁?这些解锁方法你必须知道!

在使用iPhone的过程中经常会遇到很多问题,比如忘记了iPhone的锁屏密码。面对这样的情况,许多用户可能会感到手足无措。别担心,本文将为您详细介绍iPhone忘记锁屏密码的解锁方法,让您轻松解决这一烦恼。 一、使用iTunes备份恢复 如…

以gitee为例的git入门使用指北

安装git 在linux中我们首先需要使用 sudo apt install git来下载git 在windows中可以下载msysGit 链接:https://git-scm.com/download/win gitee准备 申请账号 建立仓库 ​ 点击新建仓库 这里一般是私有库,点击创建,这时你就拥有一个线上…

python作业五

题目:注册登录 制作一个注册登录模块 注册:将用户填入的账户和密码保存到一个文件(users.bin) 登陆:将用户填入账户密码和users.bin中保存的账户密码进行比对,如果账户和密码完全相同 那 么登录成功,否则登录失败…

电脑屏幕监控软件有哪些?8款受欢迎的电脑屏幕监控软件

电脑屏幕监控软件有哪些?8款受欢迎的电脑屏幕监控软件 市场上有很多监控软件,因为太多,很多老板不知道怎么选,今天小编从它们各自的特点、优势、未来发展趋势几方面,介绍8款受欢迎的电脑屏幕监控软件。 第一是&#x…

探索网站支付系统的奥秘,从Vue3和Spring Boot开始(入门级项目实战+在线教程)附赠项目源码!

你是否曾经在购物时,对着电脑屏幕前的“支付成功”四个字感到好奇?这背后的秘密究竟是什么? 今天,让我们一起揭开支付系统的神秘面纱,探索其背后的技术实现。 在这个基于Vue3和Spring Boot的支付项目实战中&#xff…

Java实名认证API、婚恋网实名认证

中国网络婚恋交友行业发展近20年,电脑端网络婚恋服务已经较为成熟,商业模式也较为完善。但随着移动互联网的快速发展,移动端成为婚恋交友企业核心用户新的来源渠道。网络婚恋交友移动端人群覆盖规模逐渐超过电脑端人群,标志着以移…