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

【Django】QuerySet以及Pickle 序列化在Django中的深度运用详解

QuerySet QuerySet本身可以在不访问数据库的情况下构造、过滤、切片或复制和分配。只需要在需要从数据库检索数据或将数据保存到数据库时访问数据库。...Django为此提供了count()方法。 Pickle 序列化 QuerySet 如果pickle以序列化QuerySet,这将强制在pickle序列化之前将所有结果加载到内存中。...为了实现这一点,大多数QuerySet方法返回一个新的查询集。本节稍后将详细介绍这些方法。...表达式可以是简单值、对模型(或任何相关模型)字段的引用,或计算与QuerySet中的对象相关的对象的聚合表达式(平均值、总和等)。...使用关键字参数指定的注释使用关键字作为注释的别名。匿名参数将根据聚合函数的名称和聚合模型字段为其生成别名。只有引用单个字段的聚合表达式才能成为匿名参数。其他所有内容都必须是关键字参数。

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

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

    聚合 Django数据库抽象API描述了使用Django查询来添加、删除、查询和修改单个对象的方法。然而,有时需要根据一组对象聚合您想要获得的值。...第一种方法是从整个QuerySet生成摘要值。例如,想计算所有在售图书的平均价格。Django的查询语法提供了一种描述所有藏书的方法。 传递给聚合()的参数描述了要计算的聚合值。...使用后,它将返回一个“name value”字典,其中“name”是聚合值的标志,“value”是计算的聚合结果。名称是根据字段名称和聚合函数自动生成的。...如果要指定聚合值的名称,可以在指定聚合子句时提供指定的名称。...但是,有时要聚合的值属于所查询模型的关联模型。 在聚合函数中指定聚合字段时,Django允许您在筛选相关字段时使用相同的双下划线符号。Django将处理需要检索和聚合相关值的任何表连接。

    2K40

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

    然而,你有时候会想要获取从一组对象导出的值或者是聚合一组对象。这份指南描述了通过Django查询来生成和返回聚合值的方法。 整篇指南我们都将引用以下模型。这些模型用来记录多个网上书店的库存。...第一种方法是从整个查询集生成统计值。比如,你想要计算所有在售书的平均价钱。Django的查询语法提供了一种方式描述所有图书的集合。...查询集参考中列出了聚合函数的列表。 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。键的名称是聚合值的标识符,值是计算出来的聚合值。...Practical Django Projects> >>> q[1].authors__count 1 和使用 aggregate()一样,注解的名称也根据聚合函式的名称和聚合字段的名称得到的。...不是在原始的 QuerySet返回结果中对每个对象中添加注解,而是根据定义在values() 子句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值, 这个注解值是根据分组中所有的成员计算而得的

    1.7K30

    Django 聚合与查询集API实现侧边栏

    2.django提供了两种生成聚合的方法 1)从整个查询集生成统计值,主要用法:aggregate(*args, **kwargs) aggregate()是QuerySet 的一个终止子句,也就是说...aggregate返回一个字典,包含根据QuerySet 计算得到的聚合值(平均数、和等等)。...,键为聚合值的标识符,由字段和聚合函数的名称自动生成 ,值为计算出来的聚合值 >>> Book.objects.aggregate(average_price=Avg('price')) {'average_price...,但只有作者名称和average_rating 注解会返回在输出结果中 4.查询集(QuerySet)API 查询 本质上,可以创建、过滤、切片和传递查询集而不用真实操作数据库。...order_by(*fields): 默认情况下,QuerySet 根据模型Meta 类的ordering 选项排序。你可以使用order_by 方法给每个QuerySet 指定特定的排序。

    1.5K20

    django 1.8 官方文档翻译: 2-5-1 管理器 (初稿)

    你可以通过重写 Manager.get_queryset() 的方法来覆盖 管理器自带的 查询集。get_queryset() 会根据你所需要的属性返回 查询集。...私有方法(前面带一个下划线)默认不被复制。 带queryset_only 属性,并且值为False的方法总是被复制。 带 queryset_only 属性,并且值为True 的方法不会被复制。...在这种情况下,Django 必须要能看到相关模型的所有对象,所以才能根据关联关系得到任何数据 。...如果你重写了 get_queryset() 方法并且过滤掉了一些行数据,Django 将返回不正确的结果。不要这么做!...在 get_queryset()方法中过滤掉数据,会使得它所在的管理器不适于用做自动管理器。

    98120

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

    python:3.5、3.6、3.7、3.8 django:2.2、3.0、3.1 DRF : 3.10+ 简单入门 Django-filter 提供了一种基于用户提供的参数过滤查询集的简单方法。...,希望让我们的用户根据名称、价格或发布日期进行过滤 exact 精准查找,等价于filter(name=xx),对应sql语句 where name='xx'; iexact 使用 like 进行查找,...自定义过滤字段 Filter.method 您可以通过指定 method 执行过滤来控制过滤器的行为。在方法参考中查看更多信息。...='icontains') class Meta: model = Product 过滤器有两个主要参数: field_name: 要过滤的模型字段的名称。...过滤器查找类型“精确”是隐式默认值,因此永远不会添加到过滤器名称中。在上面的示例中,发布日期的确切过滤器是`release_date`,而不是`release_date__exact`。

    2.3K20

    【愚公系列】2022年04月 Python教学课程 74-DRF框架之过滤

    通常,您希望 API 限制查询集返回的项目。 筛选子类的任何视图的查询集的最简单方法是重写该方法。...GenericAPIView.get_queryset() 重写此方法允许您以多种不同的方式自定义视图返回的查询集。...1.针对当前用户进行筛选 您可能希望筛选查询集,以确保仅返回与发出请求的当前经过身份验证的用户相关的结果。 为此,可以基于用户值进行筛选。...= queryset.filter(purchaser__username=username) return queryset 二、通用过滤 除了能够重写默认查询集之外,REST 框架还包括对通用筛选后端的支持...search_fields = ['username', 'email', 'profile__profession'] 4.3 嵌套查找 对于 JSONField 和 HStoreField 字段,您可以使用相同的双下划线表示法根据数据结构中的嵌套值进行查找

    2.5K30

    Django内置的通用类视图及实例

    属性: model: 指定模型 tempalta_name:模板文件 queryset:指定一个经过过滤的对象列表,将取代model提供的值 context_object_name: 指定要在上下文中使用的变量的名称...方法: get_queryset():获取此视图的对象列表.必须是可迭代或者可以使查询集.默认返回queryset属性.可以通过重写该方法实现动态过滤.让这种方式能够工作的关键点,在于当类视图被调用时...属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...方法: get_queryset():返回用来获取本视图显示对象的queryset.如果设置了queryset属性,get_queryset()默认返回它的值. get_object(queryset=...根据报错的提示,我们可以直接在视图下给success_url参数赋值,或在模型中去定义get_absolute_url()方法,去设置成功后跳转的url。

    2.9K40

    【Django】 开发:数据库操作和后台管理

    查询数据 数据库的查询需要使用管理器对象进行 通过 MyModel.objects 管理器方法调用查询接口 方法 说明 all() 查询全部记录,返回QuerySet查询对象 get() 查询符合条件的单一记录...:order_by 用法:MyModel.objects.order_by (’- 列’,‘列’) 作用: 与 all () 方法不同,它会用 SQL 语句的 ORDER BY 子句对查询结果进行根据某个字段选择性的进行排序...,都要使用聚合查询 不带分组聚合 不带分组的聚合查询是指导将全部数据进行集中统计查询 聚合函数【需要导入】: 导入方法: from django.db.models import * 聚合函数: Sum...方法分组聚合得到分组结果 QuerySet.annotate (名 = 聚合函数 (‘列’)) 返回 QuerySet 结果集,内部存储结果的字典 如: pub_count_set = pub_set.annotate...list_filter 设置激活 Admin 修改列表页面右侧栏中的过滤器 search_fields 设置启用 Admin 更改列表页面上的搜索框。

    4.1K40

    【Python全栈100天学习笔记】Day41 Django深入理解框架

    说明3:可以在QuerySet上使用update()方法一次更新多个对象。...删除 >>> Dept.objects.get(pk=40).delete() (1, {'hrs.Dept': 1}) Django模型最佳实践 正确的为模型和关系字段命名。...不要对QuerySet调用len()函数。 将QuerySet的exists()方法的返回值用于if条件。 用DecimalField来存储货币相关数据而不是FloatField。...,是否允许为NULL,默认为False choices 设定字段的选项,各元组中的第一个值是设置在模型上的值,第二值是人类可读的值 db_column 字段对应到数据库表中的列名,未指定时直接使用字段的名称...unique 设置为True时,表中字段的值必须是唯一的 verbose_name 字段在后台模型管理显示的名称,未指定时使用字段的名称 ForeignKey属性 limit_choices_to:值是一个

    2.3K30

    Django内置的通用类视图CBV及示例

    属性: model: 指定模型 tempalta_name:模板文件 queryset:指定一个经过过滤的对象列表,将取代model提供的值 context_object_name: 指定要在上下文中使用的变量的名称...方法: get_queryset():获取此视图的对象列表.必须是可迭代或者可以使查询集.默认返回queryset属性.可以通过重写该方法实现动态过滤.让这种方式能够工作的关键点,在于当类视图被调用时...属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...方法: get_queryset():返回用来获取本视图显示对象的queryset.如果设置了queryset属性,get_queryset()默认返回它的值. get_object(queryset=...根据报错的提示,我们可以直接在视图下给success_url参数赋值,或在模型中去定义get_absolute_url()方法,去设置成功后跳转的url。

    3.2K10

    【愚公系列】2022年01月 Python教学课程 42-Django框架之ORM中查询详解

    实现SQL中的where功能,包括 filter过滤出多个结果 exclude排除掉符合条件剩下的结果 get过滤单一结果 对于过滤条件的使用,上述三个方法相同,故仅以filter进行讲解。...过滤条件的表达语法如下: 属性名称__比较运算符=值 # 属性名称和比较运算符间使用两个下划线,所以属性名不能包括多个下划线 查询编号为1的图书 查询书名包含'湖'的图书 查询书名以'部'结尾的图书...1 关联过滤查询 由多模型类条件查询一模型类数据: 语法如下: 关联模型类名小写__属性名__条件运算符=值 注意:如果没有"__运算符"部分,表示等于。...PeopleInfo: 王语嫣>, <PeopleInfo 6.查询集QuerySet 1 概念 Django的ORM中存在查询集的概念。...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。

    1.9K40

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

    Django有两种方法来生成聚合。...第一种方法是为整个QuerySet生成聚合值,例如为全部的books生成price的平均值: >>> from django.db.models import Avg >>> Book.objects.all...Generating aggregates for each item in a QuerySet 这是生成聚合值的第二种方法。...在第二个查询中,过滤器在注解之前,所以,在计算注解值时,过滤器就限制了参与运算的对象的范围 order_by() 可以根据聚合值进行排序 >>> Book.objects.annotate(num_authors...就不是在原始的 QuerySet 返回结果中对每个对象中添加注解,而是根据定义在 values() 从句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值,这个注解值是根据分组中所有的成员计算而得的

    1.1K20

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

    verbose,输出日志级别名称、日志信息,以及生成日志信息的时间、进程、线程和模块。 定义两个过滤器: project.logging.SpecialFilter,使用别名 special。...如果这个过滤器需要额外的参数,它们可以作为过滤器配置字典中的附加键提供。在这种情况下,当实例化 SpecialFilter 时,参数 foo 将被赋予一个 bar 的值。...在使用Django的ORM框架时可以基于如下方法: 对于多对一关联(如投票应用中的老师和学科),我们可以使用QuerySet的用select_related()方法来加载关联对象; 而对于多对多关联...可以用QuerySet的only()方法来指定需要查询的属性,也可以用QuerySet的defer()方法来指定暂时不需要查询的属性,这样生成的SQL会通过投影操作来指定需要查询的列,从而改善查询性能,...如果想要获得学科的名称而不是编号,可以按照如下所示的方式调整代码: queryset = Teacher.objects.values('subject__name').annotate(good=Avg

    28410

    django 1.8 官方文档翻译: 3-4-2 内建显示视图

    (publisher__name='Acme Publishing') template_name = 'books/acme_list.html' 注意,除了经过过滤之后的查询集,一起定义的还有我们自定义的模板名称...如果我们不这么做,通过视图会使用和 “vanilla” 对象列表名称一样的模板,这可 能不是我们想要的。 另外需要注意,这并不是处理特定出版商的图书的非常优雅的方法。...详见基于类的视图参考。 动态过滤 另一个普遍的需求是在给定的列表页面中根据URL中的关键字来过滤对象。...相当方便的是, ListView 有一个get_queryset() 方法来供我们重写。在之前,它只是返回一个queryset属性值,但是现在我们可以添加更多的逻辑。...pk - 这个名字是DetailView用来查找主键的值的默认名称,其中主键用于过滤查询集。

    1.4K40

    Django Template层之Template概述

    TEMPLATES配置为一个list列表,每个列表代表一个引擎,默认值为空list。...DIRS 定义引擎查找模板源文件的目录 APP_DIRS 告诉引擎是在已安装应用内部查找模板,每个backend在应用内部,按约定名称定义了用于存储模板一个目录。...engines 略 Django模板语言 变量(Variables) 变量输出来自context的值,context-类似字典的对象 变量采用{{ }} 包围,例子: html模板 <!...%}Hello, {{ user.username }}.{% endif %} 一些例子: 例1:根据用户是否登录展示不同的内容 {% if user.is_authenticated %} ...: Person object>]> 说明: all()方法会返回数据库表中所有记录的结果集,等同于以下sql SELECT 语句 SELECT * FROM `myapp_person` 组件(Commponents

    91210
    领券