Django ORM深度游:探索多对一、一对一与多对多数据关系的奥秘与实践

在这里插入图片描述

系列文章目录

  • Django入门全攻略:从零搭建你的第一个Web项目
  • Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作
  • Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
  • Django ORM深度游:探索多对一、一对一与多对多数据关系的奥秘与实践
  • 还在写0.0…

文章目录

  • 系列文章目录
  • 前言
  • 一、多对一关系
    • 1.多对一关系是什么
    • 2.多对一关系的增删改操作
    • 3.多对一的正向查询
    • 4.多对一的反向查询
  • 二、一对一关系
    • 1.一对一关系是什么
    • 2.一对一关系的增删改操作
    • 3.一对一关系正向查询
    • 4.一对一关系反向查询
  • 三、多对多关系
    • 1.多对多关系是什么
    • 2.多对多关系的外键添加操作
    • 3.多对多关系的外键移除工作
    • 4.多对多关系的修改和查询


前言

    在Django开发中,数据关系的管理至关重要。今天,我们将快速了解Django ORM如何处理多对一、一对一和多对多这三种核心数据关系。这些基础知识将帮助你更高效地构建数据库驱动的应用。让我们一起探索Django ORM的奥秘吧!


一、多对一关系

1.多对一关系是什么

Django使用django.db.models.ForeignKey定义多对一关系。

博客表—用户表 - - - 多对一

# app/model.py
class UserModel(models.Model):name = models.CharField(max_length=50)age = models.IntegerField()height = models.DecimalField(max_digits=3, decimal_places=2)def __str__(self):return self.nameclass Meta:db_table = 'users'class BlogModel(models.Model):title = models.CharField(max_length=100)content = models.TextField()pub_date = models.DateField()address = models.CharField(max_length=50)user = models.ForeignKey(to=UserModel, on_delete=models.CASCADE)def __str__(self):return self.titleclass Meta:db_table = 'blogs'

2.多对一关系的增删改操作

增:

    # 1.添加useru1 = UserModel.objects.create(name="王五", age=18, height=1.78)# 2.为 id(pk) = 1的用户添加blogu2 = UserModel.objects.get(pk=1)blog = BlogModel()blog.title = "ORM关联模型"blog.content = "多对一、一对一、多对多模型"blog.pub_date = "2024-05-31"blog.address = "csdn"blog.user = u2blog.save()

改:

    # 1.修改用户信息# u3 = UserModel.objects.get(id=1)# u3.age = 100# u3.save()# 2.修改博客信息# b3 = BlogModel.objects.get(id=9)# b3.address = "修改后的CSDN地址"b3 = BlogModel.objects.filter(id=9).update(address="再修改(update)后的CSDN地址")# b3.save()

删:

    # 1.删除blog表中的记录,直接删除# blog = BlogModel.objects.get(pk=10)# blog.delete()# 2.删除user表中数据,此user对应的blog也会删除u4 = UserModel.objects.get(pk=2)u4.delete()

3.多对一的正向查询

	# 多查询一的情况下,直接通过模型类中的外键关联字段查询# 正向查询b5 = BlogModel.objects.get(user_id=1)print(b5)print(b5.user.name)print(b5.user.age)print(b5.user.height)
>>>ORM关联模型
>>>张安
>>>100
>>>1.96  

4.多对一的反向查询

    # 反向查询:主表通过blogmodel_set查从表u6 = UserModel.objects.get(id=1)print(u6)b6 = u6.blogmodel_set.all()print(b6)for blog in b6:print(blog.title)print(blog.content)

二、一对一关系

1.一对一关系是什么

模型类使用OneToOneField用来定义一对一关系;

学生表与学生信息表 - - - 一对一
models.CASCADE:多表关联, 删除数据的时候 一删就全删

#app/model.py
class StudentModel(models.Model):name = models.CharField(max_length=50)age = models.IntegerField()height = models.DecimalField(max_digits=3, decimal_places=2)def __str__(self):return self.nameclass Meta:db_table = 'students'class StuDetail(models.Model):address = models.CharField(max_length=50)idcard = models.CharField(max_length=50)outlook = models.CharField(max_length=50)student = models.OneToOneField(to=StudentModel, on_delete=models.CASCADE)def __str__(self):return self.idcardclass Meta:db_table = 'detail'

其中,ON DELETEON UPDATE 表示事件触发限制,各参数意义如下:

参数意义
RESTRICT限制外表中的外键改动(默认值,也是最安全的设置)
CASCADE跟随外键改动
SET NULL设为null值
NO ACTION无动作
SET DEFAULT设为默认值

2.一对一关系的增删改操作

增:

    # 1.增加学生 Studentst1 = StudentModel()st1.name = "张三三"st1.age = 18st1.height = 1.79st1.save()# 2.增加学生信息 StuDetailsd1 = StuDetail()sd1.address = "北京"sd1.idcard = 123sd1.outlook = '团员'sd1.student = st1sd1.save()

改:

    # 3.修改 学生详细信息sd2 = StuDetail.objects.get(id=1)sd2.address = "我在中东吃炸鸡"sd2.save()# 4.修改 学生信息st2 = StudentModel.objects.get(id=1)st2.age = 12st2.save()

删:

    # 5.删除st5 = StudentModel.objects.get(id=1)st5.delete()

3.一对一关系正向查询

    # 5.正向查询:sd3 = StuDetail.objects.get(id=1)print(sd3.address)print(sd3.idcard)print(sd3.outlook)print(sd3.student.name)print(sd3.student.age)

4.一对一关系反向查询

	# 6.反向查询:st4 = StudentModel.objects.get(id=1)print(st4.name)print(st4.age)print(st4.studetail.address)print(st4.studetail.idcard)print(st4.studetail.outlook)

三、多对多关系

1.多对多关系是什么

多对多关系在模型中使用ManyToManyField字段定义

多对多关系可以是具有关联,也可以是没有关联,所以不需要明确指定on_delete属性
原因:在多对多的情况,有专门的第三张表,存储 对应关系, 表本身并没有字段来存储对应关系,此时删除任意数据,不影响另一张表数据

电影表与演员表 - - - 多对多

# app/models.py
class ActorModel(models.Model):name = models.CharField(max_length=50)age = models.IntegerField()gender = models.CharField(max_length=2)def __str__(self):return self.nameclass Meta:db_table = 'actors'class MovieModel(models.Model):name = models.CharField(max_length=50)mtime = models.CharField(max_length=50)info = models.CharField(max_length=50)actors = models.ManyToManyField(to=ActorModel)def __str__(self):return self.nameclass Meta:db_table = 'movies'

2.多对多关系的外键添加操作

创建:

    # 1.添加演员a1 = ActorModel()a1.name = '刘海柱'a1.age = 32a1.gender = '男'a1.save()#a2 = ActorModel()a2.name = '赵小刀'a2.age = 30a2.gender = '女'a2.save()#a3 = ActorModel()a3.name = '哈士奇'a3.age = 33a3.gender = '男'a3.save()-------------------------------------------# 2.添加电影信息m1 = MovieModel()m1.name = "精武门"m1.mtime = "2h"m1.info = "这是一个武打片"m1.save()m2 = MovieModel()m2.name = "ye邪不压正"m2.mtime = "2h30min"m2.info = "这肯呢个肯呢个可能是一个武打片"m2.save()m3 = MovieModel()m3.name = "don东北黑道纷纭"m3.mtime = "2h50min"m3.info = "黄及哦啊哦写"m3.save()

增加:

	# 3.给电影添加演员--正向的a1 = ActorModel.objects.get(id=1)a2 = ActorModel.objects.get(id=2)a3 = ActorModel.objects.get(id=3)# 给任意一个电影添加对应的演员m1 = MovieModel.objects.get(id=1)m1.actors.add(a1)m1.actors.add(a2)m1.actors.add(a3)
---------------------------------------------# 4.给演员安排几个电影拍m2 = MovieModel.objects.get(id=2)m3 = MovieModel.objects.get(id=3)a1 = ActorModel.objects.get(id=1)a1.moviemodel_set.add(m2,m3)

3.多对多关系的外键移除工作

多对多关联字段的删除,要使用remove来进行关系的断开
而不是直接使用deleteremove只会断开数据之间的联系,但是不会将数据删除

    # 5.删除,会删除电影及电影-演员表中的对应关系# MovieModel.objects.get(id=1).delete()# 6.删除对应关系:从某电影m6中移除某演员a1,只影响演员-电影对应关系表m6 = MovieModel.objects.get(id=6)a1 = ActorModel.objects.get(id=1)a1.moviemodel_set.remove(m6)

4.多对多关系的修改和查询

    # 7.查询数据# 根据任意一个电影,查询所有参演的演员-m1 = MovieModel.objects.get(id=1)print("-"*10)print(m1.actors.all())# 根据任意一个演员,查询拍过的所有电影 f反向查询a1 = ActorModel.objects.get(id=1)print("-"*10)print(a1.moviemodel_set.all())

在这里插入图片描述

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

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

相关文章

面试题--this关键字

this 指向是前端面试中的常问题型,简单分析为以下几种: 1. 在全局作用域中,this 关键字固定指向全局对象 window 或者 global。 2. 在函数作用域中,取决于函数是如何被调用的。 1)函数直接调用,this 指向…

Leetcode 3169. Count Days Without Meetings

Leetcode 3169. Count Days Without Meetings 1. 解题思路2. 代码实现 题目链接:3169. Count Days Without Meetings 1. 解题思路 这一题的话我们只需要先对meeting的时间进行一下排序,然后不断更新当前连续开会的时间即可。当某一个会议开始时&#…

Java中lambda表达式是啥怎么使用

在Java中,Lambda表达式(也称为闭包)是一种简洁地表示匿名函数(即没有名称的函数)的方式。它们允许你将函数作为参数传递或赋值给变量,从而简化代码。Lambda表达式在Java 8及更高版本中引入。 Lambda表达式…

打造智能化未来:智能运维系统架构解析与应用实践

在数字化转型的大背景下,智能运维系统成为了企业提升效率、降低成本、增强安全性的关键利器。本文将深入探讨智能运维系统的技术架构,介绍其核心要素和应用实践,帮助读者全面了解智能运维系统的概念、优势和应用价值。 ### 1. 智能运维系统的…

如何进入 -MGMTDB目录

想想这个问题,大家可能觉得很简单吧,先不看答案,你试一试如何进去 1.问题现象: 我直接进入: cd -MGMTDB 直接就报错了: [gridhost03 _mgmtdb]$ cd -MGMTDB -bash: cd: -M: invalid option cd: usage: c…

Rust struct

Rust struct 1.实例化需要初始化全部成员变量2.如果需要实例化对象可变,加上mut则所有成员变量均可变 Rust支持通过已实例化的对象,赋值给未赋值的对象的成员变量 #![allow(warnings)] use std::io; use std::error::Error; use std::boxed::Box; use s…

【NumPy】深入解析numpy中的 iscomplex 方法

🌈 欢迎莅临我的个人主页👈这里是我深耕Python编程、机器学习和自然语言处理(NLP)领域,并乐于分享知识与经验的小天地!🎇 🎓 博主简介: 我是云天徽上,一名对技…

下载文件流

export function downloadFile(file, name, type) { const link document.createElement(‘a’) link.href window.URL.createObjectURL(new Blob([file], { type: type })) link.target ‘_blank’ link.download name document.body.appendChild(link) link.click() docu…

Mujoco仿真【xml文件的学习 4】

在学习Mujoco仿真的过程中,mujoco的版本要选择合适。先前我将mujoco的版本升级到了mujoco-3.1.4,在运行act的仿真代码时遇到了问题,撰写了博客: Aloha机械臂的mujoco仿真问题记录-CSDN博客 下面在进行mujoco仿真时,统…

从0开发一个Chrome插件:开发Chrome插件的必要知识

前言 这是《从0开发一个Chrome插件》系列的第二篇文章,本系列教你如何从0去开发一个Chrome插件,每篇文章都会好好打磨,写清楚我在开发过程遇到的问题,还有开发经验和技巧。 专栏: 从0开发一个Chrome插件:什么是Chrome插件? 尽请期待~ Chrome 插件的基本结构 一个C…

Superset二次开发之PG数据库备份策略

背景:基于Superset项目3.0版本二次开发,线上运行之后,需要处理和维护后续的PG数据的备份,迁移,回滚,校验等环节 Superset 默认使用 PostgreSQL(简称 PG)作为其元数据数据库。这个数据库在 Superset 项目中扮演了关键角色: 存储元数据: PG 数据库存储 Superset 的所有…

十_信号3-可重入函数

如上图所示链表,在插入节点的时候捕获到了信号,并且该信号的自定义处理方式中也调用了插入节点的函数。 在main函数中,使用insert向链表中插入一个节点node1,在执行insert的时,刚让头节点指向node1以后(如上图序号1)&…

MySQL学习——获取数据库和表格的信息

如果忘记了数据库或表的名称,或者不确定给定表的结构(例如,其列的名称),该怎么办呢?MySQL通过几个语句解决了这个问题,这些语句提供了有关它支持的数据库和表的信息。 你之前已经看过SHOW DATA…

linux系统下,mysql增加用户

首先,在linux进入mysql mysql -u root -p 然后查看当前用户: select user,host from user; 增加用户语句: CREATE USER 用户名host范围 IDENTIFIED BY 密码;

【操作系统】Linux、Windows各平台CoreDump机制实现详解

LinuxCoreDump机制是Unix/Linux操作系统中的一种功能,它允许在程序异常终止时,将程序的内存状态保存到一个文件中,这个文件通常被称为core文件。以下是CoreDump机制的原理和实现步骤: 信号触发:CoreDump通常由特定的信…

【C++】C++入门1.0

鼠鼠最近在学C,那么好,俺来做笔记了! 目录 1.C关键字(C98) 2.命名空间 2.1.命名空间定义 2.2.命名空间的使用 3.C的输入&&输出 4.缺省参数 4.1缺省参数概念 4.2.缺省参数的分类 5.函数重载 5.1.函数重载概念 5.2.C支持函数…

深度学习-04-数值的微分

深度学习-04-数值的微分 本文是《深度学习入门2-自製框架》 的学习笔记,记录自己学习心得,以及对重点知识的理解。如果内容对你有帮助,请支持正版,去购买正版书籍,支持正版书籍不仅是尊重作者的辛勤劳动,也…

SHA256计算原理

标签: SHA256计算原理;SHA256;SHA-2; SHA-256计算原理 SHA-256(Secure Hash Algorithm 256-bit)是SHA-2系列中的一种哈希算法,它由美国国家安全局(NSA)设计,并由美国国家标准与技术研究院(NIST)发布。SHA-256主要用于数据完整性验证和数字签名等领域。以下是SHA-…

所有人都可以做的副业兼职,短剧推广,1天挣几百,附详细方法!

自从上次向大家介绍了短剧掘金项目以来,便陆续收到了众多朋友的询问:现在是否还能加入短剧掘金的大军?答案是肯定的。目前,无论是各大视频平台还是其他渠道,短剧掘金项目都呈现出蓬勃发展的态势。而且,相关…

SSM高校社团管理系统-计算机毕业设计源码86128

目 录 摘要 1 绪论 1.1研究背景与意义 1.2开发现状 1.3研究方法 1.4 ssm框架介绍 1.5论文结构与章节安排 2 高校社团管理系统系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1数据增加流程 2.2.2数据修改流程 2.2.3数据删除流程 2.3 系统功能分析 2.3.1 功能性分…