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

Django学习笔记之Django QuerySet的方法

一般情况下,我们在写Django项目需要操作QuerySet时一些常用的方法已经满足我们日常大多数需求,比如get、filter、exclude、delete神马的感觉就已经无所不能了,但随着项目但业务逻辑越来越复杂...就是你读出queryset可能会需要一些额外数据要添加进去的时候,你就可以用这个东东咯,使用方法看代码: >>> q = Blog.objects.annotate(Count('entry')) #...,annotate返回的是一个包含注解值的queryset,而aggregate则单独返回注解值,返回类型是一个dict,当然,这种方式在文档中叫做聚合查询,具体使用如下: >>> q = Blog.objects.aggregate...django才会从数据库读取这些数据,感觉在数据量变大后用这个方法很nice,具体用法如下: Blog.objects.defer("content").filter(publish=True).defer...12、Avg、Count、Sum、Max、Min、StdDev、Variance 这些方法就是求数据的相应结果咯,比如avg就是平均值啦,嗯,基本都看得懂,除了后两个,一个是方差,一个是标准差,具体用法其实前文里有

59150

Django中的QuerySet

一、QuerySet   查询集,类似一个列表,包含了满足查询条件的所有项。QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作。只有你查询的时候才真正的操作数据库。...意味着QuerySet是惰性执行的----即创建查询集不会带来任何的数据库访问,直到查询集需要求值的时候,Django才会真正运行这个查询。...常用的QuerySetf方法 all(): 查询所有结果 filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)。... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。

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

    Django的Manager和QuerySet

    Django的Manager和QuerySet 要从数据库检索对象,需要通过模型类的 Manager 构建一个 QuerySet。...models本身没有什么需要多说的,Django 使用了一套直观的系统:一个模型类代表一张数据表,一个模型类的实例代表数据库表中的一行记录。 模型类的save方法可以插入,更新,删除数据。...可以根据给定参数缩小查询结果量。在 SQL 的层面上, QuerySet 对应 SELECT 语句,而filters对应类似 WHERE 或 LIMIT 的限制子句。...使用len()函数求QuerySet的长度,比起使用QuerySet的count()方法效率要低一些,count()方法实际对应于数据库的聚合函数COUNT,它是数据库层面的操作,而非python。...下面介绍一下常用的可以返回QuerySet对象的QuerySet方法 不能返回QuerySet对象的QuerySet方法 下面介绍一些常用的不能返回QuerySet对象的QuerySet方法。

    1.1K30

    【实测】django的QuerySet 应该怎么用?

    其实就是查询的意思。 所以,queryset 是什么?是查询结果的集合的意思。 我就不用那些标准的百度百科的回答了,咱直接上代码,从数据直接拿出来的数据来当例子,你就明白了。...好然后我们用一段函数来把数据从中取出来并打印: 结果如下: 可以看到,直接从数据库用.all 或者.filter方法拿出来的 结果是queryset,也就是查询集合。...所以queryset的另一个特性就是可以像列表一样遍历和用下标定位具体内部元素: 遍历的具体子元素,都是一个个货真价实的数据记录哈。 别看我直接输出,就显示一个link_name的值。...此时我们得到的仍然是queryset,但结果中,却显示了所有字段。 这样我们用起来就更方便。为什么这么说呢? 因为我们可以把它外面再加上list() 变成我们python常用的格式了。...注意,此时的结果,变成了 列表里面套字典的样式,这回我们可以说随便摆弄了吧? 而且这个格式,可以直接传给前端的js函数中也就是bom层来使用。

    64110

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

    切片未执行的QuerySet通常会返回另一个未执行的Query Set。但是,如果使用切片语法的step参数,Django将执行数据库查询并返回一个列表。...Django为此提供了count()方法。 Pickle 序列化 QuerySet 如果pickle以序列化QuerySet,这将强制在pickle序列化之前将所有结果加载到内存中。...这意味着当取消缓存QuerySet时,它包含缓存时的结果,而不是数据库中当前的结果。 如果只想提取将来从数据库中重新创建QuerySet所需的信息,请提取QuerySet的查询属性。...为了实现这一点,大多数QuerySet方法返回一个新的查询集。本节稍后将详细介绍这些方法。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。

    1.8K10

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

    本文从Django官方文档总结而来,将聚合的主要用法和查询集的常见方法做一归纳。 聚合 1....聚合的产生来源于django数据库查询,通常我们使用django查询来完成增删查改,但是有时候需要更复杂的方法才能完成对数据的提取、筛选、更改,所以需要一组对象聚合来完成这种操作。...2.django提供了两种生成聚合的方法 1)从整个查询集生成统计值,主要用法:aggregate(*args, **kwargs) aggregate()是QuerySet 的一个终止子句,也就是说...每本书和作者是多对多的关系。我们想要汇总QuerySet.中每本书里的这种关系。逐个对象的汇总结果可以由annotate()子句生成。...annotate()子句的返回结果是一个查询集 (QuerySet);这个 QuerySet可以用任何QuerySet方法进行修改,包括 filter(), order_by()。

    1.5K20

    ES 基于查询结果的聚合

    在了解本文内容前,必须先了解ES DSL查询和ES 聚合查询,ES基于查询结果的聚合分为两种,第一种类似与关系型数据库中的Having语法,第二种类似于关系型数据库中先where在group by的语法...,本文主要分析先查询后聚合场景 演示数据从ES 聚合查询获取 1、先查询后聚合 现在需要统计价格在50到500价格范围区间的所有食物,并按照标签进行聚合查询,代码如下: GET food/_search...field": "Tags.keyword", "order": { "_count": "asc" } } } } } 搜索结果如下...{ "key" : "水果", "doc_count" : 2 } ] } } } hits中是按照query查询的结果集...,下面是根据query的结果集进行的聚合查询. 2、先聚合后查询(注意这里不是having语法,而是查询聚合里面的详情) 通过post_filter实现 现在需要查询价格范围在50到500之间,按照标签分组之后

    1.4K30

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

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

    2K40

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

    网站:http://python.usyiyi.cn/django/index.html 聚合 Django数据库抽象API描述了使用Django查询来增删查改单个对象的方法。...然而,你有时候会想要获取从一组对象导出的值或者是聚合一组对象。这份指南描述了通过Django查询来生成和返回聚合值的方法。 整篇指南我们都将引用以下模型。这些模型用来记录多个网上书店的库存。...Django提供了两种生成聚合的方法。...annotate()子句的返回结果是一个查询集 (QuerySet);这个 QuerySet可以用任何QuerySet方法进行修改,包括 filter(), order_by(), 甚至是再次应用annotate...Django 永远不会 删除你所指定的排序限制(我们不能改动那些方法的行为,因为这会违背 API stability 原则)。 聚合注解 你也可以在注解的结果上生成聚合。

    1.7K30

    Django之ORM数据库

    注意: 第二种方式修改不能用get的原因是:update是QuerySet对象的方法,get返回的是一个model对象,它没有update方法,而filter返回的是一个QuerySet对象(filter...id" = 3; 此外,update()方法对于任何结果集(QuerySet)均有效,这意味着你可以同时更新多条记录update()方法会返回一个整型数值,表示受影响的记录条数。...是惰性的 Django的queryset对应于数据库的若干记录(row),通过可选的查询来过滤。...聚合查询和分组查询 aggregate(*args,**kwargs):    通过对QuerySet进行计算,返回一个聚合值的字典。...键的名称是聚合值的 标识符,值是计算出来的聚合值。键的名称是按照字段和聚合函数的名称自动生成出来的。

    2.6K10

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

    文章目录 一、基础条件查询 1.基本查询 2.过滤查询 3.F和Q对象 4.聚合函数和排序函数 5.关联查询 6.查询集QuerySet ---- 一、基础条件查询 1.基本查询 get查询单一结果,如果不存在会抛出模型类...功能,包括 filter过滤出多个结果 exclude排除掉符合条件剩下的结果 get过滤单一结果 对于过滤条件的使用,上述三个方法相同,故仅以filter进行讲解。...聚合函数包括:Avg平均,Count数量,Max最大,Min最小,Sum求和,被定义在django.db.models中。 例:查询图书的总阅读量。...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。...使用同一个查询集,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。

    1.9K40

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

    删除单个MyModel对象或删除一个查询结果集(QuerySet)中的全部对象都是调用 delete()方法 删除单个对象 步骤 查找查询结果对应的一个数据对象 调用这个数据对象的 delete ()...,都要使用聚合查询 不带分组聚合 不带分组的聚合查询是指导将全部数据进行集中统计查询 聚合函数【需要导入】: 导入方法: from django.db.models import * 聚合函数: Sum...分组聚合是指通过计算查询结果中每一个对象所关联的对象集合,从而得出总计值 (也可以是平均值或总和),即为查询集的每一项生成聚合。...语法: QuerySet.annotate (结果变量名 = 聚合函数 (‘列’)) 用法步骤: 通过先用查询结果 MyModel.objects.values 查找查询要分组聚合的列 MyModel.objects.values...方法分组聚合得到分组结果 QuerySet.annotate (名 = 聚合函数 (‘列’)) 返回 QuerySet 结果集,内部存储结果的字典 如: pub_count_set = pub_set.annotate

    4.1K40

    Django的聚合查询与原生操作

    以下是Django Shell的执行结果 >>> Asset.objects.aggregate(数据库ID行数=Count('id')) {'数据库ID行数': 4} 返回的结果是以字典的方式组成的{...结果变量名:值} 分组聚合 ​ 分组聚合是指通过计算查询结果中每一个对象所关联的对象集合,从而得出总计值,即为查询集的每一项生成聚合。...通过先用查询结果Mymodels.objects.values查找要分组聚合的列 from django.db.models import * from apps.monitor.models import...QuerySet.annotate方法分组聚合得到分组结果 QuerySet.annotate(结果变量名=聚合函数('列')) print(select.annotate(myCount=Count(...'id'))) 分组聚合的返回值为QuerySet 原生数据库操作 django也可以支持直接使用SQL语句进行查询数据库 查询:使用MyModels.objects.raw()进行数据库查询操作

    69020

    Django之QuerySet详解

    从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet。...换句话说,用order_by()方法对QuerySet对象进行操作会返回一个扩大版的新QuerySet对象。因此,使用多值字段对结果进行排序时要格外小心。 没有方法指定排序是否考虑大小写。...对于大小写的敏感性,Django将根据数据库中的排序方式排序结果。...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。...对于返回大量只需要访问一次的对象的QuerySet,这可以带来更好的性能,显著减少内存使用。 请注意,在已经提交了的iterator()上使用QuerySet会强制它再次提交数据库操作,进行重复查询。

    2.4K20

    Django之ORM对数据库操作

    QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)。... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。...() 特殊的QuerySet values() 返回一个可迭代的字典序列 values_list() 返回一个可迭代的元祖序列 返回具体对象的 get() first() last() 返回布尔值的方法有...换句话说,在关联的任何一端,都不需要再调用save()方法。 聚合查询和分组查询 聚合 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。...键的名称是聚合值的标识符,值是计算出来的聚合值。键的名称是按照字段和聚合函数的名称自动生成出来的。

    1.3K110
    领券