Django 学习第八天——Django模型基础第三节
一、表关系的实现:

一对一:OneToOne(外键+唯一键)
xxx = models.OneToOneField('关联的表',on_delete=models.CASCADE)
外键和一对一关系的时候需要加 on_delete 选项,此参数为了避免两个表里的数据不一致问题,不然会报错! 使用 CASCADE 表示级联删除:关联表中的数据删除了,这张表中对应的数据也会删除
一对多:OneToMany(外键)
xxx = models.ForeignKey('关联的表',on_delete=models.SET_NULL,null=True)
外键和一对一关系的时候需要加 on_delete 选项,此参数为了避免两个表里的数据不一致问题,不然会报错! 使用 SET_NULL 表示关联表中数据删除不会影响到该表中数据,该字段就为空;加上非空键,让这条字段可以为空
多对多:ManyToMany(表关联:外键+联合唯一)
#只需要一个字段和id时不用创建第三张表,会自动创建第三张表
xxx = models.ManyToMany('关联的表')
# 如果还有其他字段时,就需要创建中间表
xxx = models.ManyToMany('关联的表',through='通过第三张表关联')
创建模型类


执行完 makemigrations 和 migrate 的命令后,在数据库我们能看到5张表,其中多对多关系的ManyToManyField 方法自动生成了关系表.
二、关联表的数据操作:
一对多表关系数据操作:
正向:一个模型如果定义了一个外键字段,通过这个模型操作外键就叫正向
增,改:
第一种:跟之前一样,用传参的方法添加,需要注意的是外键的值必须是关联表中已经存在的值

第二种:用属性赋值的方式,因为我们再模型类有定义一个 xxx 的属性,而这个属性的对象的类型必须是 xxx 表的类实例对象
外键 关联的表中的数据必须是已存在的(该表中的 外键字段_id 相当于关联表中的 id)

删:
外键字段必须加上 null=True 才能删除
查出该字段,赋值为 None 就可以删除了
查:
表实例. 外键字段. 关联表中的字段

要查某个学院有多少个学生:
学生表.objects.filter(外键字段__学院名字段=’学院‘)
反向:从关联表的表反过来查关联它的表的数据
如果模型I有一个ForeignKey,那么该ForeignKey 所指的模型II实例可以通过一个管理器回前面有ForeignKey的模型I的所有实例。默认情况下,这个管理器的名字为 源模型的小写名_set(foo_set)
可以再定义是设置 related_name 参数来覆盖 源模型的小写名_set 的名称
增:
关联表的实例. 小写源表名_set. create( )
关联表的实例. 小写源表名_set. add( )

查:
关联表的实例. 小写源表名_set. 单表查询的所有方法都可以用

删:
删一个:
关联表的实例. 小写源表名_set. remove(要删除的数据)
删多个:
关联表的实例. 小写源表名_set. remove(要删除的数据,要删除的数据)
删完:
关联表的实例. 小写源表名_set. clear()
改:
关联表的实例. 小写源表名_set. set([添加的数据,添加的数据])
会先执行 clear() 方法在添加
多对多表关系数据操作:
没有指定中间表的时候:
add,remove,set 都不能用了,必须用中间表操作数据
有指定中间表的时候:

不借助中间表,关联的表可以相互访问,查询
一对一表关系数据操作:
正向和一对多相似
反向;直接通过 模型的小写 ;不用 _set 了
三、跨表查询:
Django 提供一种强大而又直观的方式来“处理”查询中的关联关系,它在后台自动帮你处理JOIN。 若要跨越关联关系,只需使用关联的模型字段的名称,并使用双下划线分隔,直至你想要的字段:
例如:
# 查询学院名字为‘计算机学院’的学生的信息 Student.objects.filter(department__name='计算机学院')
它还可以反向工作。若要引用一个“反向”的关系,只需要使用该模型的小写的名称。
#查询学生名字中包含 '小' 的学生的学院信息
Department.objects.filter(student__name__contains='小') # contains 模糊查询
# 查询学号为1的学生所有的课程
Course.objects.filter(student__s_id=1) # 查询报了课程1的所有的学生
Student.objects.filter(course__c_id=1) # 查询报了'python'课程的的学生的所属学院的信息
Department.objects.filter(student__course__name='python') # 查询报了'english'课程的 33 期的学员
Student.objects.filter(course__name='english',grade__num='')
Django 学习第八天——Django模型基础第三节的更多相关文章
- django学习-数据库配置-创建模型
数据库配置 在mysite/settings.py中,包含了django项目设置的python模块 通常,这个配置文件使用SQLite作为默认数据库.如果你不熟悉数据库,或者只是想尝试下django, ...
- Django 学习第一天——django 基本介绍和环境搭建
web 应用设计模式(MTV MVC): MTV: M:models 模型:负责业务数据对象与数据库对象: T:templates 模板:负责如何把数据展示给用户: V:views 视图:负责业务逻辑 ...
- Django学习笔记之Django中间件
准备 我们在前面的课程中已经学会了给视图函数加装饰器来判断是用户是否登录,把没有登录的用户请求跳转到登录页面.我们通过给几个特定视图函数加装饰器实现了这个需求.但是以后添加的视图函数可能也需要加上装饰 ...
- Django学习之六:Django 常用模块导入记忆
Django 常用模块导入记忆 django相关 1. urls相关操作 from django.urls import path, re_path, include from django.urls ...
- Django学习笔记之Django Form表单
Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否 ...
- Django学习笔记之数据库-模型的操作
模型的操作 在ORM框架中,所有模型相关的操作,比如添加/删除等.其实都是映射到数据库中一条数据的操作.因此模型操作也就是数据库表中数据的操作. 添加模型 添加模型到数据库中.首先需要创建一个模型.创 ...
- Django学习系列13:Django ORM和第一个模型
ORM—对象关系映射器,是一个数据抽象层,描述存储在数据库中的表,行和列.处理数据库时,可以使用熟悉的面向对象方式,写出更好的代码. 在ORM的概念中,类对应数据库中的表,属性对应列,类的单个实例表示 ...
- Django (学习第二部 ORM 模型层)
Django对数据库的操作 Django的 ORM 简介 ORM操作 (增删改查) ORM操作数据库的增删改查 ORM创建表关系 ORM中常用字段及参数 数据库的查询优化 ORM中如何开启事务 ORM ...
- django 数据库配置 ,APP 迁移.模型基础
# 1.数据库的连接配置django 连接mysql的配置流程:- 安装 pymysql pip install pymysql- 创建数据库用户有创建数据库权限的用户- 创建数据库crm .进入数据 ...
随机推荐
- Let the Balloon Rise <map>的应用
Contest time again! How excited it is to see balloons floating around. But to tell you a secret, the ...
- 如何在地址栏(title标签里)和收藏夹里 加上网站的标志ICO、LOGO图片
第一步:首先你必须要制作一个看起来既清楚又容易辨识的.ico格式的小图片. 我们将图标的大小定义为16x16 像素.此外在制作图形文件的时候,你可能需要把色盘设定成只使用标准的 16 色 Window ...
- ESD选型指南
信息来自网络,可能有误,希望指正! 一.ESD工作原理 ESD静电保护元件,又称静电抑制二极管.ESD是多个TVS晶粒或二极管采用不同的布局做成具有特定功能的多路或单路ESD保护器件,主要应用于各类通 ...
- mysql下载源码方法
方法一 进入mysql官网:http://dev.mysql.com/downloads/mysql/ 选择相关的平台下载: 3.选择Source Code 选型后,拉倒网页下方,选择要下载的源码包 ...
- js 对象(object)合并
var obj1 = { name:'lisi', checked:'true' }; var obj2 = { name:'zhangsan', age:18 }; Object.assign(ob ...
- XMind思维导图使用笔记
首先新建一个空白的图 以组织结构图(向下) 为例 1.双击组织结构图 创建一个空白的页面 2.随便选择一个风格 这时候出现工作台 现在里面只有一个中心主题 正文部分开始 1.如果想要添加一个子主题 ...
- ubuntu下如何编译C语言
ubuntu下如何编译C语言 如果没有gcc编译器的话,使用以下命令获取 ~# sudo apt-get install gcc同时要下载辅助工具 ~# sudo apt-get instal ...
- phoenix表操作
phoenix表操作 进入命令行,这是sqlline.py 配置到path环境变量的情况下 sqlline.py localhost如果要退出命令行:!q 或者 !quit 3.4.1 创建表 ...
- C#学习-字段
字段的定义由3部分组成,访问修饰符.字段的类型和字段的名称.以下是 public class Person { //姓名,类型为字符串类型 private string name; //年龄,类型为i ...
- C#default关键字(泛型代码中的默认关键字)
在泛型类和泛型方法中产生的一个问题是,在预先未知以下情况时,如何将默认值分配给参数化类型 T:T 是引用类型还是值类型.如果 T 为值类型,则它是数值还是结构.给定参数化类型 T 的一个变量 t,只有 ...