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

Django—模型

,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...4.查询集 查询集表示从数据库中获取的对象集合,在管理器上调用某些过滤器方法会返回查询集,查询集可以含有零个、一个或多个过滤器。...过滤器基于所给的参数限制查询的结果,从Sql的角度,查询集和select语句等价,过滤器像where和limit子句。 返回查询集的过滤器如下: all():返回所有数据。...缓存:使用同一个查询集,第一次使用时会发生数据库的查询,然后把结果缓存下来,再次使用这个查询集时会使用缓存的数据。 查询集的缓存 每个查询集都包含一个缓存来最小化对数据库的访问。...在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中,并返回请求的结果,接下来对查询集求值将重用缓存中的结果。

6.1K21

【Django】聚合在Django的详细解析以及运用在企业级项目里的方法

聚合 Django数据库抽象API描述了使用Django查询来添加、删除、查询和修改单个对象的方法。然而,有时需要根据一组对象聚合您想要获得的值。...本主题指南介绍如何使用Django查询生成和返回聚合值。...例如,我们可以查询每个作者,并注释作者(联合)创建的书籍的总页数(注意我们如何使用“book”指定author->book反转多对多跳转): Author.objects.annotate(total_pages...例如,可以使用查询生成所有书籍的注释列表。此列表的标题以“Django”开头。...很难直观地理解ORM如何将复杂的查询集转换为SQL查询。因此,如果有疑问,请使用str(queryset.query)`检查SQL并编写大量测试。

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

    python测试开发django-169.过滤器django-filter 入门使用

    前言 在管理后台查询的时候,经常有需要查询包含某个内容,按时间段查询,或者商品价格大于多少,小于多少各种查询条件。 django-filter 过滤器专门解决这种查询的问题。...python:3.5、3.6、3.7、3.8 django:2.2、3.0、3.1 DRF : 3.10+ 简单入门 Django-filter 提供了一种基于用户提供的参数过滤查询集的简单方法。...假设我们有一个Product模型,我们想让我们的用户过滤他们在列表页面上看到的产品。...自定义过滤字段 Filter.method 您可以通过指定 method 执行过滤来控制过滤器的行为。在方法参考中查看更多信息。...='icontains') class Meta: model = Product 过滤器有两个主要参数: field_name: 要过滤的模型字段的名称。

    2.3K20

    Web | Django 与数据库交互,你需要知道的 9 个技巧

    查询集的结果变为具名元组(QuerySet results as namedtuples) 我是一个 namedtuples 的粉丝,同时也是 Django 2.0 的 ORM 的粉丝。...限制(Limit) 这与设置边界的最后一点有些相关。有时我们的客户的一些行为是不可预知的。比如,同一用户打开另一个选项卡并在第一次尝试「卡住」时再试一次并不罕见。...事务操作通常会涉及用户和产品的一些属性,所以我们经常使用 select_related 来强制 join 并保存一些查询。 更新交易还会涉及获得一个锁来确保它不被别人获得。 现在,你看到问题了吗?...并不是,数据库为特定用例提供其他类型的索引也蛮多的。 从 Django 1.11 开始,有一个新的 Meta 选项用于在模型上创建索引。这给了我们探索其他类型索引的机会。...现在回到 Django,我们有哪些常被索引的字段,最有可能在磁盘上自然排序?没错,就是 auto_now_add。

    2.9K40

    django 1.8 官方文档翻译: 2-2-1 执行查询

    执行查询 一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行增删改查的操作。这篇文档阐述了如何使用这些API。关于所有模型检索选项的详细内容,请见数据模型参考。...使用过滤器获取特定对象 all()方法返回的结果集中包含全部对象,但是更普遍的情况是你需要获取完整集合的一个子集。 要创建这样一个子集,需要精炼上面的结果集,增加一些过滤器作为条件。...针对这两种情况,Django 用一种很方便的方式来使用 filter() 和 exclude()。对于包含在同一个 filter() 中的筛选条件,查询集要同时满足所有筛选条件。...要牢住上面所说的缓存行为,否则在使用 QuerySet 时可能会给你造成不小的麻烦。...你可以设置和获得外键属性。正如你所期望的,改变外键的行为并不引发数据库操作,直到你调用 save()方法时,才会保存到数据库。

    4.4K20

    Django相关知识点回顾

    无论是字典、列表或者元组的元素,都需要使用 .取值,下标或者键名,不能使用 [],这是和Flask有区别的地方。...{% empty %} # 遍历为空时的逻辑 {% endfor %} 13.2.3模板过滤器 a) Jinja2模板过滤器使用 {{ 模板变量|过滤器(参数...)}} b) Django中模板过滤器的使用...QuerySet(查询集) exclude 查询条件 返回不满足条件的所有数据 QuerySet(查询集) order_by 排序字段 对查询结果进行排序 QuerySet(查询集) aggregate...()过滤器调用聚合函数 排序: 排序默认是升序,降序在排序字段前加- 使用order_by 关联查询: 1.查询和指定对象关联的数据 # 由1查多 一对象.多类名小写_set.all() 例:book.heroinfo_set.all...查询结果的缓存 使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来,下一次再使用这个查询集时,使用的Django之前存储的结果。

    10K51

    django_2

    要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询集 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象..., 如果使用选项设置某属性为主键列后, 则django不会再生成默认的主键列 ·属性命名限制 ·遵循标识符规则 ·由于django的查询方式,不允许使用连续的下划线 库...Django有两种过滤器用于筛选记录: filter:返回符合筛选条件的数据集 exclude :返回不符合筛选条件的数据集 链式调用: 多个filter和exclude可以连接在一起查询 Person.objects.filter...查询集可以有多个过滤器。...过滤器:过滤器就是一个函数,基于所给的参数限制查询集结果,返回查询集的方法称为过滤器。 查询经过过滤器筛选后返回新的查询集,所以可以写成链式调用。

    3.6K30

    Django模型model

    会为表增加自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列 属性命名限制 不能是python的保留关键字 由于django的查询方式,不允许使用连续的下划线...模型类中字段选项 通过字段选项,可以实现对字段的约束 在字段对象时通过关键字参数指定 null:如果为True,Django 将空值以NULL 存储到数据库中,默认值是 False blank:如果为True...模型类的查询 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句...接下来主要讨论如下知识点 查询集 字段查询:比较运算符,F对象,Q对象(1)模型类查询集合 在管理器上调用过滤器方法会返回查询集 查询集经过过滤器筛选后返回新的查询集,因此可以写成链式过滤 惰性执行:...创建查询集不会带来任何数据库的访问,直到调用数据时,才会访问数据库 何时对查询集求值:迭代,序列化,与if合用 返回查询集的方法,称为过滤器,管理器对象方法有all()、filter()、exclude

    15310

    Django学习笔记之Django ORM Aggregation聚合详解

    ('price')) {'price__avg': 34.35, 'price__max': Decimal('81.20'), 'price__min': Decimal('12.99')} 为查询集的每个对象生成聚合值...联合聚合Joins and aggregates 目前为止,我们聚合查询的field都属于我们要查询的Model,我们也可以用其它Model的field来进行聚合查询,例如: >>> from django.db.models...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的好书(评分大于3分)总数。在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...在第二个查询中,过滤器在注解之前,所以,在计算注解值时,过滤器就限制了参与运算的对象的范围 order_by() 可以根据聚合值进行排序 >>> Book.objects.annotate(num_authors...=Count('authors')).order_by('num_authors') values() 通常,注解annotate是添加到每一个对象上的,一个执行了注解操作的查询集 QuerySet 所返回的结果中

    1.1K20

    37.Django1.11.6文档

    当你最初获取数据时不知道是否需要这些特定字段的情况下,如果你正在使用查询集的结果,你可以告诉Django不要从数据库中检索它们。...form.instance.name = name 使用自定义查询集 如前所述,您可以覆盖模型formset使用的默认查询集: from django.forms import modelformset_factory...表单集还可以索引,它将返回对应的表单。 如果覆盖__iter__,你还需要覆盖__getitem__ 以获得一致的行为。 使用formset 的初始数据 初始数据体现着表单集的主要功能。 ...如果您使用initial来显示表单集,则在处理该表单的提交时,应该传递相同的initial,以便表单集可以检测用户更改哪些表单。...它接受请求,应用当前过滤器的查询集以及用户提供的搜索项。 它返回一个包含被修改以实现搜索的查询集的元组,以及一个指示结果是否可能包含重复项的布尔值。

    24.4K80

    Django学习笔记 1.7 自定义 admin 站点

    当我们的拥有数十个字段的表单,我们肯定会期望将表单分为几个字段集,这样会更清晰一点: from django.contrib import admin from .models import Question...默认提供 3 个足够的选项字段。” 3 自定义后台更改列表 3.1 显示列表 默认情况下,Django 显示每个对象的 str() 返回的值。但有时如果我们能够显示单个字段,它会更有帮助。...为此,使用 list_display 后台选项,它是一个包含要显示的字段名的元组,在更改列表页中以列的形式展示这个对象: class QuestionAdmin(admin.ModelAdmin):...list_display = ('question_text', 'pub_date') 3.2 过滤器 再次编辑文件 polls/admin.py,优化 Question 变更页:过滤器,使用 list_filter...你可以使用任意多的字段——由于后台使用 LIKE 来查询数据,将待搜索的字段数限制为一个不会出问题大小,会便于数据库进行查询操作。 END ----

    99420

    Django3.2边学边记—Adimn站点管理

    页大小 每页中显示多少条数据,默认为每页显示100条数据,设置为20 12 class TestAdmin(admin.ModelAdmin):    list_per_page = 20 操作选项的位置...atitle.short_description='标题'   如果是更改模型字段显示的列标题,可以在定义模型字段时,设置verbose_name的值 ,或者封装成方法,再对方法使用上面那个属性,模型字段不能直接使用那个属性...用 list_filter 来激活管理更改列表页面右侧侧栏的过滤器,如下截图所示: list_filter 应是一个元素的列表或元组,会将对应字段的值列出来,一般用于快速过滤有重复值的字段 12...12 class TestAdmin(admin.ModelAdmin):    search_fields = ['id','name'] 在搜索框中进行搜索时,Django 会将搜索查询拆分成多个词...,你可以使用 ModelAdmin.get_search_results() 来提供额外的或替代的搜索行为。

    1.2K00

    django 1.8 官方文档翻译: 2-5-4 聚合 (初稿)

    Django 文档协作翻译小组人手紧缺,有兴趣的朋友可以加入我们,完全公益性质。...网站:http://python.usyiyi.cn/django/index.html 聚合 Django数据库抽象API描述了使用Django查询来增删查改单个对象的方法。...第一种方法是从整个查询集生成统计值。比如,你想要计算所有在售书的平均价钱。Django的查询语法提供了一种方式描述所有图书的集合。...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的图书总数。 在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...这个行为与查询集文档中提到的 distinct() 一样,而且生成规则也一样:一般情况下,你不想在结果中由额外的字段扮演这个角色,那就清空排序项,或是至少保证它仅能访问 values()中的字段。

    1.7K30

    35.Django2.0文档

    过滤器使用管道字符, {{ name|lower }} #它功能是转换文本为小写。...M:数据存取部分,由django数据库层处理,本章要讲述的内容。   V:选择显示哪些数据要显示以及怎样显示的部分,由视图和模板处理。   ...该层处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等    T:代表模板(Template),即表现层。...其他的一些查找类型有:   icontains(大小写无关的LIKE),startswith和endswith, 还有range 5.获取单个对象 上面的例子中`` filter()`` 函数返回一个记录集...也就是说,这些修改实质上是构成模块的一部分,并且正好被管理工具使用,而不是专门针对管理工具的。 除了这些,Django还提供了大量选项让你针对特别的模块自定义管理工具。

    11.3K100

    Python全栈开发之Django基础

    的选项使用 unique:如果为True, 这个字段在表中必须有唯一值,默认值是False 条件查询 查询 exact 表示判等 list = BookInfo.objects.filter(id__exact...() 查询集 查询集表示从数据库中查询到的对象集合 返回查询集的过滤器 all():返回所有数据 filter(): 返回满足条件的数据 exclude(): 返回不满足条件的数据 order_by()...: 对结果集排序 返回单个值的过滤器 get(): 返回单个满足条件的对象,如果未找到会抛出DoesNotExist异常,如果返回多条抛出MultipleObjectReturnned异常 count(...): 返回当前查询结果的总条数 aggregate(): 聚合,返回一个字典 判断一个查询集中是否有数据 两个特性 惰性 创建查询集不会访问数据库,直到调用数据时,才会访问数据库 缓存 使用同一个结果集...,第一次使用会触发查询数据库,然后将结果缓存下载,再次使用直接调用缓存 限制结果集 可以对结果集进行切片操作,等同于数据库中的分页操作,但是不支持负数 list = BookInfo.objects.all

    3.8K20

    django 1.8 官方文档翻译: 2-6-4 数据库访问优化

    Django 文档协作翻译小组人手紧缺,有兴趣的朋友可以加入我们,完全公益性质。...理解查询集 理解查询集(QuerySets) 是通过简单的代码获取较好性能至关重要的一步。特别是: 理解查询集计算 要避免性能问题,理解以下几点非常重要: QuerySets是延迟的。...使用iterator() 当你有很多对象时,QuerySet的缓存行为会占用大量的内存。这种情况下,采用iterator()解决。...在数据库中而不是Python中做数据库的工作 比如: 在最基础的层面上,使用过滤器和反向过滤器对数据库进行过滤。 使用F 表达式在相同模型中基于其他字段进行过滤。 使用数据库中的注解和聚合。...有可能你会做很多次数据库查询,但只需要一次就够了。

    1.1K30

    Django3.2边学边记—Adimn站点管理

    页大小 每页中显示多少条数据,默认为每页显示100条数据,设置为20 12 class TestAdmin(admin.ModelAdmin):    list_per_page = 20 操作选项的位置...atitle.short_description='标题'   如果是更改模型字段显示的列标题,可以在定义模型字段时,设置verbose_name的值 ,或者封装成方法,再对方法使用上面那个属性,模型字段不能直接使用那个属性...),会将对应字段的值列出来,一般用于快速过滤有重复值的字段。...12 class TestAdmin(admin.ModelAdmin):    search_fields = ['id','name'] 在搜索框中进行搜索时,Django 会将搜索查询拆分成多个词...,你可以使用 ModelAdmin.get_search_results() 来提供额外的或替代的搜索行为。

    1.3K30

    查询集 QuerySet和管理器Mana

    当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。 filter():返回满足条件的数据。 exclude():返回满足条件之外的数据。...对查询集可以再次调用过滤器进行过滤,如 BookInfo.objects.filter(bread__gt=30).order_by('bpub_date') 从SQL的角度讲,查询集与select语句等价...() 继续执行遍历迭代操作后,才真正的进行了数据库的查询 for book in qs: print(book.btitle) 2>缓存 使用同一个查询集,第一次使用时会发生数据库的查询,然后Django...会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。...qs = BookInfo.objects.all()[0:2] 管理器manager 自定义manager 注意:一旦为模型类指明自定义的过滤器后,Django不再生成默认管理对象objects。

    1.1K40

    Django实践-07日志调试,Django-Debug-Toolbar配置与sql优化

    与此同时,采集日志数据也是为网站做数字化运营奠定一个基础,通过对系统运行日志的分析,我们可以监测网站的流量以及流量分布,同时还可以挖掘出用户的使用习惯和行为模式。...verbose,输出日志级别名称、日志信息,以及生成日志信息的时间、进程、线程和模块。 定义两个过滤器: project.logging.SpecialFilter,使用别名 special。...5xx响应被视为错误消息;4xx响应被记录为警告消息;其他一切都被记录为INFO django.template - 与模板渲染相关的日志消息 django.db.backends - 有与数据库交互产生的日志消息...,这里我们关注的是ORM框架生成的SQL查询到底是什么样子的, 相信这里的结果会让你感到有一些意外。...“N+1查询”),原本获取老师的数据只需要一条SQL,但是由于老师关联了学科,当我们查询到N条老师的数据时,Django的ORM框架又向数据库发出了N条SQL去查询老师所属学科的信息。

    28610
    领券