关系字段 ForeignKey 外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。 ...ForeignKey可以和其他表做关联关系同时也可以和自身做关联关系。...字段参数 to:设置要关联的表; related_name:反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'(同ForeignKey字段)。...order_with_respect_to 这个选项一般用于多对多的关系中,它指向一个关联对象。就是说关联对象找到这个对象后它是经过排序的。...ordering 这个字段是告诉Django模型对象返回的记录结果集是按照哪个字段排序的。
---- FileField 字符串(储存文件路径),Django Admin以及ModelForm中提供读取文件夹下文件的功能 关系字段 ---- ForeignKey ...外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。 ...---- ManyToManyField 用于表示多对多的关联关系。在数据库中通过第三张表来建立关联关系。...---- through 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...---- ordering 指定默认按什么字段排序。 只有设置了该属性,我们查询到的结果才可以被reverse()。
大家好,又见面了,我是你们的朋友全栈君。 Django中的ORM Django项目使用MySQL数据库 1....关系字段 ForeignKey 外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。...ForeignKey可以和其他表做关联关系同时也可以和自身做关联关系。...在数据库中通过第三张表来建立关联关系。 字段参数 to 设置要关联的表 related_name 同ForeignKey字段。 related_query_name 同ForeignKey字段。...ordering 指定默认按什么字段排序。 只有设置了该属性,我们查询到的结果才可以被reverse()。
ordering 指定默认按什么字段排序。...反向查询(按表名:book_set,因为加上_set是因为反向查询的时候,你查询出来的可能是多条记录的集合): publish=Publish.objects.get(name="苹果出版社") #publish.book_set.all...) egon.authorDeail就拿到了这个对象,因为一对一找到的就是一条记录,注意写法:作者对象.字段名,就拿到了那个关联对象 反向查询(按表名:author):不需要_set,因为一对一正向反向都是找到一条记录...正向查询(按字段:authors): 反向查询(按表名:book_set): 注意: 你可以通过在 ForeignKey() 和ManyToManyField的定义中设置 related_name...''' 基于双下划线的查询就一句话:正向查询按字段,反向查询按表名小写用来告诉ORM引擎join哪张表,一对一、一对多、多对多都是一个写法,注意,我们写orm查询的时候,哪个表在前哪个表在后都没问题
其它属性详情请查看:官方文档 关系字段 ForeignKey 外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 ‘一对多’中’多’的一方。...ForeignKey可以和其他表做关联关系同时也可以和自身做关联关系。...on_delete:同ForeignKey字段。 ManyToManyField 在数据库中通过第三张表来建立关联关系。...through:在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...index_together: 联合索引 unique_together: 联合唯一索引 ordering: 指定默认按什么字段排序。只有设置了该属性,我们查询到的结果才可以被reverse()。
(): 对查询结果反向排序 count(): 返回数据库中匹配查询(QuerySet)的对象数量。...,从book表查询到author表就叫做正向查询 反向查询:反过来,从author表查询到book表中,就是反向查询 正向查询按字段,反向查询按表名小写_set.all() ---- 需求:查询红楼梦书所有的作者...正向:正向查询按字段 反向查询:反向按表名小写_set.all() 4******基于对象的查询,多次查询(子查询) 打印Django查询数据的SQL语句...**ForeignKey** 外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。...ordering 指定默认按什么字段排序。 只有设置了该属性,我们查询到的结果才可以被reverse()。
order_by(*field): 对查询结果排序 reverse(): 对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的...此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)...它存在于下面两种情况: 外键关系的反向查询 多对多关联关系 简单来说就是当 点后面的对象 可能存在多个的时候就可以使用以下的方法。...中每一个对象都生成一个独立的统计值。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。
注意事项: 表的名称myapp_modelName,是根据 模型中的元数据自动生成的,也可以覆写为别的名称 id 字段是自动添加的 对于外键字段,Django 会在字段名上添加"_id" 来创建数据库中的列名...定义好模型之后,你需要告诉Django _使用_这些模型。你要做的就是修改配置文件中的INSTALL_APPSZ中设置,在其中添加models.py所在应用的名称。...基于双下划线的跨表查询 Django 还提供了一种直观而高效的方式在查询(lookups)中表示关联关系,它能自动确认 SQL JOIN 联系。...''' 正向查询按字段,反向查询按表名小写用来告诉ORM引擎join哪张表 ''' 一对多查询 # 练习: 查询苹果出版社出版过的所有书籍的名字与价格(一对多) # 正向查询 按字段...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。
在上面的例子中,对于ForeignKey关系,e.save()由关联管理器调用,执行更新操作。...对查询结果反向排序 distinct(): 从返回结果中剔除重复纪录 count(): 返回数据库中匹配查询(QuerySet)...是nid=1的书籍对象关联的出版社对象 反向查询(按表名:book_set): ?...) 反向查询(按表名:author): ?...进行排序: ?
多对一关系 Django 使用 ForeignKey 定义多对一关系。 和使用其他 字段(Field) 类型一样:在 model 当中把它做为一个类属性包含进来。...最后,如果你只想在 model 中修改 Python-level 级的行为,而不涉及字段改变。 代理 model (Proxy models) 适用于这种场合。...例如,在上面的代码中,如果去掉 related_name 属性,在 ChildA 中,m2m 字段的反向名称就是 childa_set;而 ChildB 的 m2m 字段的反向名称就是 childb_set...Django 自带的 User model 没有定义排序设置(这是故意为之,是因为排序开销极大,我们不想在获取用户时浪费额外资源)。..."] proxy = True 普通的 User 查询,其结果是无序的;而 OrderedUser 查询的结果是按 username 排序。
配置关系型数据库MySQL 我们继续来完善上一个章节中的OA项目,首先从配置项目使用的数据库开始。...Dept.objects.order_by('no')[2:4] # 按部门编号排序查询3~4部门 , ]> 高级查询。...(从一对多关系中“一”的一方查询“多”的一方),反向查询属性默认的名字是类名小写_set(如上面例子中的emp_set),当然也可以在创建模型时通过ForeingKey的related_name属性指定反向查询属性的名字...ManyToManyField属性 symmetrical:是否建立对称的多对多关系。 through:指定维持多对多关系的中间表的Django模型。...managed 设置为True时,Django在迁移中创建数据表并在执行flush管理命令时把表移除 order_with_respect_to 标记对象为可排序的 ordering 对象的默认排序 permissions
该主题 模式将包括四个领域:主题 ,最后更新 日期将被用来定义主题排序,主题起动机 来识别用户 谁开始的主题 ,和一个叫做场板 来定义哪些主板 特定主题 属于....我们将通过实现反向关系来实现这一点,其中 Django 将自动在数据库中执行查询以返回属于特定主题的所有帖子 的列表。 好的,现在足够的 UML!...该 related_name参数将用于创建 反向关系 ,其中 Board实例将有权访问 Topic属于它的实例列表。 Django 会自动创建这种反向关系——这 related_name是可选的。...在 Post模型中,该 updated_by字段设置 related_name='+'. 这告诉 Django 我们不需要这种反向关系,所以它会忽略它。...您可以在下面看到类图和使用 Django 生成模型的源代码之间的比较。绿线代表我们如何处理反向关系。 ? 类图模型定义 此时,您可能会问自己:“主键/ID 怎么样”?
order_by(*field): 对查询结果排序 reverse(): 对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的...此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)...它存在于下面两种情况: 外键关系的反向查询 多对多关联关系 简单来说就是当 点后面的对象 可能存在多个的时候就可以使用以下的方法。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...终端打印SQL语句 在Django项目的settings.py文件中,在最后复制粘贴如下代码: LOGGING = { 'version': 1, 'disable_existing_loggers
那么绑定关系只有上面一种方式 # 如果第三张表是自己创建的: class Book2Author(models.Model): author=models.ForeignKey...对查询结果反向排序 # distinct(): 从返回结果中剔除重复纪录 # values_list(*field): 它与values()非常相似,它返回的是一个元组序列...__city或者author__name中的publisher,author是book表中绑定的字段 #一对多和多对多在这里用法没区别 # 反向查找(条件)----在没有外键的表中,查找与其关联表的字段信息...,从而得出总计值(也可以是平均值或总和),即为查询集的每一项生成聚合。...F查询和Q查询 F 使用查询条件的值,专门取对象中某列值的操作 Q 查询提供了或操作 # from django.db.models import F # models.Tb1
一、django ORM简介 O(objects):类和对象。R(Relation):关系,关系数据库中的表格。M(Mapping):映射。...Django ORM框架的功能: 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。 根据设计的模型类生成数据库中的表格。 通过方便的配置就可以进行数据库的切换。...对查询结果排序 reverse() 对查询结果反向排序 distinct() 从返回结果中剔除重复记录 values_list(*field...返回数据库中匹配的对象的第一个对象 last() 返回数据库中匹配的对象的最后一个对象 exists() 判断一个对象集合中是否包含指定对象...5. reverse(): reverse() 反向排序QuerySet中返回的元素。 第二次调用reverse()将恢复到原有的排序。
blog = models.ForeignKey(Blog, to_field=Blog.name) ForeignKey.db_constraint Django Model的ForeignKey字段的主要功能是维护一个一对多的关系...ForeignKey.related_name 这个名称用于让关联的对象反查到源对象. 如果你不想让Django 创建一个反向关联,请设置related_name 为 '+' 或者以'+' 结尾....ManyToManyField.through_fields 上文示例中Membership 有两个外键指向Person (person 和inviter),这使得关联关系含混不清并让Django 不知道使用哪一个...ManyToManyField 字段的模型的外键名称(本例中为group),field2 为指向目标模型的外键的名称(本例中为person)....,可以使用db_table关键字参数指定. others 下列API和ForeignKey中的同名API相同.
多对一关系 Django 使用 django.db.models.ForeignKey 定义多对一关系。和使用其它字段类型一样:在模型当中把它做为一个类属性包含进来。...toppings = models.ManyToManyField(Topping) 和使用ForeignKey 一样,你也可以创建递归的关联关系(对象与自己的多对多关联)和与尚未定义关系的模型的关联关系...和使用 ForeignKey一样,你可以定义_ 递归的关联关系和引用尚未定义关系的模型。详见模型字段参考_。 另见 在一对一关系的模型例子 中有一套完整的例子。...例如,在上面的代码中,如果去掉 related_name属性,在 ChildA中,m2m 字段的反向名称就是 childa_set;而 ChildB的 m2m 字段的反向名称就是 childb_set。...但是这个 OnetoOneField 字段默认的 related_name 值与 ForeignKey 和 ManyToManyField 默认的反向名称相同。
什么是关系映射? 在关系型数据库中,通常不会把所有数据都放在同一张表中,不易于扩展。...级联删除的特殊字段 models.CASCADE:Django模拟SQL约束ON DELETE CASCADE,并删除包含ForeignKey的对象 注意该CASCADE会有限查找是否有关联数据,先删除管理数据...models.PROTECT:抛出ProtectedError以阻止被引用对象的删除 SET_NULL:设置ForeignKey为Null,需要指定null=True from django.db import...') 反向查询 没有外键属性的一方,可以调用反向属性查询到关联的另一方 反向关联的属性为实例对象.引用类名(小写) 当反向引用不存在的时候,则会触发异常 当UserId类中定义了外键约束...MySQL中创建多对多需要以来第三张表来完成 Django中无需手动创建,Django自动完成 语法:在关联的两个类中的任意一个类中models.ManyToManyField(MyModel
目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对多...3、一般不需要设置联级更新. 4、外键在一对多的多中设置:models.ForeignKey("关联类名", on_delete=models.CASCADE)。...(常用) 一对多中,设置外键属性的类(多的表)中,MySQL 中显示的字段名是:外键属性名_id。...book.authors.clear() 跨表查询 正向:外键字段在哪,去从该表的角度查另外的表,就是正向 反向:从没有外键表去查另外相关联的表,就是反向 口诀: 正向查询按外键字段 反向查询按表名小写...and的关系,那么或,非得关系如果构造呢?
相反地,使用ForeignKey, 反向关联后会返回QuerySet。...,再删除此字段信息的时候同时删除包含ForeignKey字段的目标(object) PROTECT 通过django.db.IntegrityError中的ProtectedError来保护此字段不被删除...,默认为字段名 related_query_name 用于filter函数过滤和values函数 to_field 关系关联的相关对象名称 db_constraint 控制在数据库中是否应该建立这一字段的约束...在概念上我们可以理解其为设置unique属性为True的一种类型,区别之处在于它“反向”的数值会返回一个目标值,这对于继承关系的表达十分有用,例如一下示例程序: from django.conf import...以上这篇基于Django OneToOneField和ForeignKey的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考。
领取专属 10元无门槛券
手把手带您无忧上云