上一篇Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询讲述了关于Django模型的F对象、Q对象、聚合查询等功能。...但是没有讲到两张表的关联查询的实现,这个在模型里面该怎么处理呢?...在进行关联查询之前,首先要了解一下模型之间的关联关系,以及相应的操作。...模型如何实现多对多的关联之后,下面来看看怎么关联查询。...模型的关联查询,也只是查询多类一方的单独数据而已。
在 Django 中,你可以使用单行查询来获取关联模型的数据。...这通常涉及使用查询集的 select_related 或 prefetch_related 方法,这两个方法允许你在一次数据库查询中获取关联模型的数据,而不是分开的多个查询。...下面是一些示例:1、问题背景在 Django 中,我们经常需要查询关联模型的数据。传统的方法是使用外键关系来获取关联模型的数据,这需要进行两次数据库查询。...为了提高效率,我们可以使用单行查询来获取关联模型的数据。...你可以根据自己的需求选择合适的方法。使用这些方法之一,我们可以在单行代码中获取关联模型的数据。这些方法可以帮助你优化数据库查询并减少不必要的查询次数,提高 Django 应用程序的性能。
关联关系操作Django提供了一系列操作,用于在关联关系上进行查询和操作。...实例,然后通过它的address属性获取关联的Address实例。...,然后通过它的book_set属性获取关联的所有Book实例。...实例,然后通过它的student_set属性获取关联的所有Student实例。...(course)在上面的代码中,我们首先获取一个Student实例和一个Course实例,然后调用Student实例的courses属性的remove方法,将这个Course实例从这个Student实例关联的多对多关系中移除
Django是一个流行的Python Web框架,其模型层允许开发人员定义数据库模型以及它们之间的关系。...这些关系被称为模型关联关系,允许开发人员在不同的模型之间建立复杂的关联关系,从而实现更高级别的数据结构。一对一关系一对一关系是指两个模型之间存在唯一的对应关系。...一对多关系一对多关系是指一个模型可以对应多个另一个模型的实例。在Django中,可以使用ForeignKey字段来定义一对多关系。...author的ForeignKey字段,它指向另一个模型Author。...多对多关系多对多关系是指两个模型之间存在多个对应关系。在Django中,可以使用ManyToManyField字段来定义多对多关系。
模型类(models.Model): # 字段名 = models.字段类型(选项参数) class 序列化器名(serializers.Serializer): # 字段名 = serializers...4.5序列化功能(重点掌握) 把实例对象转换为字典数据 知识点: 1、序列化单个对象 2、序列化多个对象 3、关联对象的嵌套序列化 1)将关联对象序列化为关联对象的主键 # 在英雄类(多)中添加 hbook...) hbook = BookInfoSerializer(label='图书') 3)将关联对象序列化为关联对象模型类_str_方法的返回值 hbook = serializers.StringRelatedField...: validate_field_name是字段名,前面是固定的。...4.7模型类序列化ModelSerializer 如果我们想要使用序列化器对应的是Django的模型类,DRF为我们提供了ModelSerializer模型类序列化器来帮助我们快速创建一个Serializer
打开Menu.vue 我们先来思考下,怎么发出一个请求来获取后台数据。 首先我们需要一个发请求的组件,也就是axios函数。...而自动触发的调用代码通常是放在mounted()属性中的。 所以代码应该是这样的: 上图中,我们弄了一个platform_list当做那个变量。同名函数来获取平台列表。...请看下图: 这里我们添加了v-for循环,i作为循环体,也就是每一个关联平台的数据字典,i.name就是展示名称。用{{}}裹起来才可以使用。...如果此时我们把后台views.py中添加一个print,就可以清晰的看到我们获取了什么东西... 刷新页面就会重新触发请求,就可以看到django控制台展示的了。...而此时的前端是这样的: 也就是说,正常展示了关联的平台。 好,本节课到此结束,下节课来实现添加关联按钮的功能。
django从入门到精通No.2----模型 一、前言 学过orm系统自然之道模型的重要性,很多web站点都需要与数据库交互,这个时候模型的设计就显得尤为重要,一个好的模型会使得项目方便管理并且易于维护...必填参数primary_key=True,则成为数据库的主键,无该字段时,django自动创建,一个model不能有两个该字段。...to_field=None # 要关联的表中的字段名称 on_delete=None # 当删除关联表中的数据时,当前表与其关联的行的行为...,必须设中间关联表,关联表设独立主键,并引入两个“多”头的表的主键作为关联表的外键。...to_field=None # 要关联的表中的字段名称 on_delete=None # 当删除关联表中的数据时,当前表与其关联的行的行为 五、管理员登陆 为了能让大家提前看到
注意事项: 表的名称myapp_modelName,是根据 模型中的元数据自动生成的,也可以覆写为别的名称 id 字段是自动添加的 对于外键字段,Django 会在字段名上添加"_id" 来创建数据库中的列名...定义好模型之后,你需要告诉Django _使用_这些模型。你要做的就是修改配置文件中的INSTALL_APPSZ中设置,在其中添加models.py所在应用的名称。...要做跨关系查询,就使用两个下划线来链接模型(model)间关联字段的名称,直到最终链接到你想要的model 为止。...,后面写values方法是获取的这些对象的属性的值,当然,可以加双下划线来连表获取其他关联表的数据,但是获取的其他关联表数据是你的这些model对象对应的数据,而关联获取的数据可能不是你想要的最大值对应的那些数据...在这些情况下,我们可以直接访问数据库,完全避开模型层。 我们可以直接从django提供的接口中获取数据库连接,然后像使用pymysql模块一样操作数据库。
模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField...长度较小的字符串 DateField 存储日期,有auto_now和auto_now_add属性 DateTimeField 存储日期和日期,两个附加属性同上 DecimalField 存储固定精度小数...related_name:用于获取关联对象的关联管理器对象(反向查询),如果不允许反向,该属性应该被设置为'+',或者以'+'结尾。 to_field:指定关联的字段,默认关联对象的主键字段。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...ManyToManyField属性 symmetrical:是否建立对称的多对多关系。 through:指定维持多对多关系的中间表的Django模型。
通常,一个模型(model)映射到一个数据库表, 基本情况: 每个模型都是一个Python类,它是django.db.models.Model的子类。 模型的每个属性都代表一个数据库字段。...Django中ORM快速入门 下面这个例子定义了一个 Person 模型,包含 first_name 和 last_name。...上传图片的高度保存的数据库字段名(字符串) height_field=None 上传图片的宽度保存的数据库字段名(字符串) DateTimeField(DateField...to_field=None, # 要关联的表中的字段名称 on_delete=None, # 当删除关联表中的数据时,...# 要关联的表中的字段名称 on_delete=None, # 当删除关联表中的数据时,当前表与其关联的行的行为
一”中关联“多”,就要指定many=True这个参数 # 比如这里要查询出属于本书的所有英雄人物的信息,字段名必须是 关联模型名+'_set'这种格式,如“heroinfo_set” heroinfo_set...一”中关联“多”,就要指定many=True这个参数 # 比如这里要查询出属于本书的所有英雄人物的信息,字段名必须是 关联模型名+'_set'这种格式,如“heroinfo_set” heroinfo_set...create和update这两个方法,create用于创建新的记录,update用于修改数据库中已有的记录。...一般来说,如果是为Django的模型类写序列化器就选择ModelsSerializer,因为它帮我们做了很多事情,需要写的代码比较少;如果后端没有对应的模型类,那么就只能选择Serializer。...校验 前面提到反序列化是从API获取数据,处理后存到数据库中。这里说的“处理”其中有一个环节就是对获取到的数据进行校验,校验合格后才能真正存储到数据库中。
,可以为Dept和Emp两个模型类添加__str__魔法方法。...语句并获取对应的结果,这一点在实际开发中需要引起注意!...模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField...related_name:用于获取关联对象的关联管理器对象(反向查询),如果不允许反向,该属性应该被设置为'+',或者以'+'结尾。 to_field:指定关联的字段,默认关联对象的主键字段。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。
Django ORM框架的功能: 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。 根据设计的模型类生成数据库中的表格。 通过方便的配置就可以进行数据库的切换。...to_field=None, # 要关联的表中的字段名称 on_delete=None, # 当删除关联表中的数据时,...=None # 要关联的表中的字段名称 on_delete=None, # 当删除关联表中的数据时,当前表与其关联的行的行为...表达式可以是简单的值、对模型(或任何关联模型)上的字段的引用或者聚合表达式(平均值、总和等)。 ...每个字典表示一个对象,键对应于模型对象的属性名称。
使用例子: bookshelf = Bookshelf.objects.get(pk=1) # 查询指定书架 bookshelf.bookinfo_set.all() # 获取该书架所有的书信息...id' def __str__(self): return self.book_name 嵌套关联(自连接/自关联): 一张表存储所有地区(省市区)信息 class AreaInfo(models.Model...) pk: 主键(primary key) 例子: BookInfo.books.filter(pk__lte=2) --- 关联查询 --- # 语法: 模型名__属性名__比较运算符 Bookshelf.objects.filter...(Max('book_time')) # aggregate(Max(xxx)) F对象(用于字段与字段的比较) 语法: 字段名1__比较运算符=F('字段名2') 字段名=F('关联模型名__...关联字段名') 例子: from django.db.models import F BookInfo.books.filter(id__exact=F('book_type_id'))
() 1.12.2定义模型类 class 模型类名(models.Model): # 字段名 = models.字段类型(选项参数) # ......,在父类的基础上,添加一些功能 class 序列化器类名(serializers.Serializer): # 字段名 = serializers.字段名(选项参数) 序列化器对象创建: 序列化器类...1.将关联对象序列化为关联对象的主键 hbook = serializers.PrimaryKeyRelatedField(label='图书',read_only=True) 2.采用指定的序列化器将关联对象进行序列化...hbook = BookInfoSerializer(label='图书') 3.将关联对象序列化为关联对象模型类_str_方法的返回值 hbook = serializers.StringRelatedField...instance.bpub_date = bpub_date instance.save() return instance 2.5.6使用序列化器改写RestAPI接口 我们举两个代表性的例子即可
: 字段的名称不能包含超过两个下划线,因为这会与Django查找语法起冲突。...SQL的一些保留字如`join,where,select则是可以在model的字段名称中使用的,因为Django在每次SQL查询中避免了可能发生的冲突。...它是提供给Django的数据库查询操作的接口,用于从数据库中获取model实例。若非特别声明Manager,它默认的名字为objects。...数据的修改 数据的删除 关联对象 关联对象 下,对于获取关联对象的机集合,有两个主要任务: 获得一条Grades数据所对应的所有学生Student 获得Student所对应的班级Grade Model...子类中的字段名不能和基类中的字段名一样,否则会报错。下面是一个例子: Student模型有三个字段,分别是name,age和home_group。
它包含了你存储的数据的重要字段和行为。通常,一个模型(model)映射到一个数据库表, 基本情况: 每个模型都是一个Python类,它是django.db.models.Model的子类。...模型的每个属性都代表一个数据库字段。 综上所述,Django为您提供了一个自动生成的数据库访问API 详询官方文档链接。...上传图片的高度保存的数据库字段名(字符串) height_field=None 上传图片的宽度保存的数据库字段名(字符串) DateTimeField(DateField...字段参数 to 设置要关联的表 to_field 设置要关联的表的字段 related_name 反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'。...through 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。
它包含了你存储的数据的重要字段和行为。通常,一个模型(model)映射到一个数据库表, 基本情况: 每个模型都是一个Python类,它是django.db.models.Model的子类。...上传图片的高度保存的数据库字段名(字符串) height_field=None 上传图片的宽度保存的数据库字段名(字符串) DateTimeField(DateField...字段参数 to:设置要关联的表 to_field:设置要关联的表的字段 related_name:反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'。...字段参数 to:设置要关联的表; related_name:反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'(同ForeignKey字段)。...ordering 这个字段是告诉Django模型对象返回的记录结果集是按照哪个字段排序的。
它包含了你所要存储的数据的基本字段和行为。 Django 遵循 DRY 原则 。目标是为了只在一个地方定义你的数据模型就可从中自动获取数据。...在这简单的投票应用中,我们将创建两个模型: Poll 和 Choice。Poll 有问题和发布日期两个字段。Choice 有两个字段: 选项 ( choice ) 的文本内容和投票数。...在本例中,我们仅定义了一个符合人类习惯的字段名 Poll.pub_date 。对于模型中的其他字段,机器名称就已经足够替代人类名称了。 一些 Field 实例是需要参数的。...按照惯例,Django 会在外键字段名上附加 “_id” 。 ( 是的,你仍然可以重写此行为。) 外键关系由 REFERENCES 语句显示声明。...>] # 获取今年发起的投票。
领取专属 10元无门槛券
手把手带您无忧上云