首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

完整的 Django 零基础教程|初学者指南 - 第 3 部分 转自:维托尔·弗雷塔斯

我们将通过实现反向关系来实现这一点,其中 Django 将自动在数据库中执行查询以返回属于特定主题的所有帖子 的列表。 好的,现在足够的 UML!...线框新主题 图 7:新主题屏幕 现在是主题屏幕,显示帖子和讨论: ? 线框帖子 图 8:主题帖子列表屏幕 如果用户单击回复按钮,他们将看到下面的屏幕,其中包含反向顺序的帖子摘要(最新的在前): ?...这将指示 Django 在 Post创建对象时设置当前日期和时间。 在模型之间创建关系的一种方法是使用 ForeignKey字段。它将在模型之间创建链接并在数据库级别创建适当的关系。...这告诉 Django 我们不需要这种反向关系,所以它会忽略它。 您可以在下面看到类图和使用 Django 生成模型的源代码之间的比较。绿线代表我们如何处理反向关系。 ?...如果我们不为模型指定主键,Django 会自动为我们生成它。所以我们现在很好。在下一节中,您将更好地了解它是如何工作的。 迁移模型 下一步是告诉 Django 创建数据库,以便我们可以开始使用它。

2.2K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Django 系列博客(十三)

    数据库中字段【年】部分是否可以建立唯一索引 verbose_name Admin中显示的字段名称 blank Admin中是否允许用户输入为空 editable...Admin中是否可以编辑 help_text Admin中该字段的提示信息 choices Admin中显示选择框的内容,用不变动的数据放在内存中从而避免跨表操作...to 设置要关联的表 to_field 设置要关联的表的字段 related_name 反向查询时,使用的字段名,用于代替原反向查询时的'表名_set'。...publish = ForeignKey(Blog, related_name='booklist') db_constraint 是否在数据库中创建外键约束,默认为 True。...在数据库中通过第三张表来建立关联关系。 to 设置要关联的表 related_name 反向查询时,使用的字段名,用于代替原反向查询时的'表名_set'。

    1.1K30

    Django之contenttypes的应用

    Django contenttypes 应用 简介 contenttypes 是Django内置的一个应用,可以追踪项目中所有app和model的对应关系,并记录在ContentType表中。...每当我们创建了新的model并执行数据库迁移后,ContentType表中就会自动新增一条记录。...从数据库查看ContentType表,显示如下: ? 那么这个表有什么作用呢?这里提供一个场景,网上商城购物时,会有各种各样的优惠券,比如通用优惠券,满减券,或者是仅限特定品类的优惠券。...在数据库中,可以通过外键将优惠券和不同品类的商品表关联起来: from django.db import models class Electrics(models.Model): """...为了更方便查询商品的优惠券,我们还可以在商品类中通过GenericRelation字段定义反向关系。

    79510

    Django之ForeignKey和ManyToManyField多表查询

    blog = models.ForeignKey(Blog, to_field=Blog.name) ForeignKey.db_constraint Django Model的ForeignKey字段的主要功能是维护一个一对多的关系...只有在db_constraint=True时Django model才会在数据库上建立外键约束, 在该值为False时不建立约束. 默认db_constraint=True....ForeignKey.related_name 这个名称用于让关联的对象反查到源对象. 如果你不想让Django 创建一个反向关联,请设置related_name 为 '+' 或者以'+' 结尾....修改e.blog并调用save方法存入数据库 >>> e.blog = some_blog >>> e.save() 如果ForeignKey 字段有null=True 设置(即它允许NULL值),可以分配...反向查询: >>>a = Person.objects.get(id=1) >>>a.group_set.all() 同样related_name可以设置反向查询集的名称。

    1.8K10

    Django官方文档小结(一) -- Models模型

    Django 关系字段 本文主要内容是关于Django框架中models的知识小结 #1 环境 Python3.7.3 Django==2.0.7 #2 字段 #2.1 一对多(ForeignKey)...与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象) #2.4 数据库表示 在生成数据库时,Django追加"_id"字段名称来创建其数据库列名,可以通过指定显式更改此内容db_column...#2.5 反向查找 (related_name) from django.db import models class Blog(models.Model): name = models.CharField....RelatedManager object at 0x10d58c908> >>> b.entryblogs.all() # 一对多,所以反向获取到的数据是一个多条数据,需要all()...]> #2.6 反向直接获取数据 (related_query_name) 正常查询 >>> b = models.Blog.objects.get(id=1

    78320

    Django ORM 多表操作

    目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对多...(ManyToManyField):在第三张关系表中新增数据 ORM 修改数据 ORM 删除和清空数据 跨表查询 基于对象的跨表查询 基于双下划线的跨表查询 聚合查询 示例 F查询 Q查询 Django...添加数据(添加外键) 一对多(外键 ForeignKey) 方式一: 传对象的形式,返回值的数据类型是对象,书籍对象 步骤: 获取出版社对象 给书籍的出版社属性 pulish 传出版社对象 '''test.py...Book object (3) if __name__ == '__main__': main() 方式二: 传对象 id 的形式(常用) 一对多中,设置外键属性的类(多的表)中,MySQL 中显示的字段名是...:从没有外键表去查另外相关联的表,就是反向 口诀: 正向查询按外键字段 反向查询按表名小写 注意: 正向:属性名 反向:小写类名加 _set 反向查询的时候查询的对象可能有多个的情况加__set,查询的对象只有一个的情况不需要加

    1.8K20

    django select_related和prefetch_related的用法与区别

    今天我们再来学习两个非常重要的查询方法select_related和prefetch_related方法,看看如何使用它们避免不必要的数据库查询。高手过招,只差分毫。...它提示我们查询了10次数据库,包括3次重复查询,一共耗时8.93ms。 什么?显示一个页面竟用了10次查询?是的,你没看错。...当我们在模板中调用{{ article.category.name }} 和 {{ tag.name }}显示category和tags的名字时,Django还需要重新查询blog_category和blog_tag...Django提供了prefect_related方法来解决这个问题。prefect_related可用于多对多关系字段,也可用于反向外键关系(related_name)。...对与单对单或单对多外键ForeignKey字段,使用select_related方法 对于多对多字段和反向外键关系,使用prefetch_related方法 两种方法均支持双下划线指定需要查询的关联对象的字段名

    1.4K20

    django 1.8 官方文档翻译: 2-1-1 模型语法(初稿)

    如果设置了 choices ,Django 的管理后台就会显示选择框,而不是标准的文本框,而且这个选择框的选项就是 choices 中的元组。...另见 ForeignKey 字段还可以接受别的参数,它们都是可选的,在 model 字段参考(the model field reference) 有详细介绍。这些选项定义了关系是如何工作的。...这是因为 Django 会对每个 SQL 查询的数据库名称和列名称做重编码,至于如何编码视你所用的数据库而定。...当某个对象被要强制转换成字符串,或是要做为字符串显示时,Python 和 Django 就会调用该方法。最典型的,在命令行或管理后台中显示对象,就会用到 unicode() 方法。...这取决于你如何使用 ‘%(class)s’ 来构造你的反向名称。如果你没有这样做,Django 就会在验证 model (或运行 syncdb) 时抛出错误。

    3.1K30

    django 1.8 官方文档翻译:2-1-1 模型语法

    另见 ForeignKey 字段还接受许多别的参数,在模型字段参考有详细介绍。这些选项帮助定义关联关系应该如何工作;它们都是可选的参数。...当模型实例需要强制转换并显示为普通的字符串时,Python 和Django 将使用这个方法。最明显是在交互式控制台或者管理站点显示一个对象的时候。 将将永远想要定义这个方法;默认的方法几乎没有意义。...小心使用 related_name 如果你在 ForeignKey或  ManyToManyField字段上使用  related_name属性,你必须总是为该字段指定一个唯一的反向名称。...这取决于你如何使用  '%(class)s' 和'%(app_label)s来构造你的反向名称。如果你没有这样做,Django 就会在验证 model (或运行 migrate) 时抛出错误。...但是这个 OnetoOneField 字段默认的 related_name 值与 ForeignKey 和 ManyToManyField 默认的反向名称相同。

    5K20

    Django之ORM字段和参数

    ---- FileField           字符串(储存文件路径),Django Admin以及ModelForm中提供读取文件夹下文件的功能 关系字段 ---- ForeignKey     ...---- auto_now    配置上auto_now=True,每次更新数据记录的时候会更新该字段。 ForeignKey参数 ---- to       设置要关联的表。...(to_field='字段名') ---- related_name   反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'。...(反向查询)时,我们就可以这么写: models.Classes.objects.first().students.all() ---- related_query_name    反向查询操作时,使用的连接前缀...---- related_query_name 同ForeignKey字段。 ---- symmetrical               仅用于多对多自关联时,指定内部是否创建反向操作的字段。

    2.3K60

    【云+社区年度正文】Django从入门到精通No.2----模型

    ,用不变动的数据放在内存中以避免跨表操作 verbose_name: 显示的字段名称 error_messages:自定义错误信息(字典类型) validators:自定义错误验证(列表类型) 注:数据参考来源...=None,# 反向操作时,使用的连接前缀,用于替换【表名】 limit_choices_to=None, # 在Admin或ModelForm中显示关联数据时,提供的条件,字典类型...db_constraint=True # 是否在数据库中创建外键约束 parent_link=False # 在Admin中是否显示关联数据 2.多对多 多对多的表...# 在Admin或ModelForm中显示关联数据时,提供的条件,字典类型 symmetrical=None # 仅用于多对多自关联时,用于指定内部是否创建反向操作的字段,...六、总结 以上就是django所有的关于模型的概念了,接下来小编将通过与数据库交互来带着大家一起操作表。

    2.1K00

    使用 Django 显示表中的数据

    1、问题背景当我们使用 Django 进行 Web 开发时,经常需要在 Web 页面上显示数据库中的数据。例如,我们可能需要在一个页面上显示所有用户的信息,或者在一个页面上显示所有文章的标题和作者。...那么,如何使用 Django 来显示表中的数据呢?2、解决方案为了使用 Django 显示表中的数据,我们需要完成以下几个步骤:在 models.py 文件中定义数据模型。...数据模型是 Django 用于表示数据库中数据的类。...例如,如果我们想显示所有用户的信息,那么我们可以在 models.py 文件中定义如下数据模型:from django.db import modelsclass User(models.Model):...例如,如果我们想在一个页面上显示所有用户的信息,那么我们可以在 views.py 文件中定义如下视图函数:from django.shortcuts import renderdef users(request

    12310
    领券