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

如何再次过滤django查询集以获得唯一的参数?

在Django中,可以使用.distinct()方法来过滤查询集以获得唯一的参数。.distinct()方法用于从查询集中去除重复的结果。

例如,假设有一个模型Book,其中有一个字段author表示书籍的作者。要获取所有不重复的作者,可以使用以下代码:

代码语言:txt
复制
unique_authors = Book.objects.values('author').distinct()

上述代码中,.values('author')用于指定只获取author字段的值,然后.distinct()方法用于去除重复的结果。

关于Django的查询集过滤和去重,可以参考腾讯云文档中的相关内容:Django查询集API文档

请注意,以上答案仅供参考,具体的实现方式可能会根据具体的业务需求和数据模型而有所不同。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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

执行查询 一旦你建立好数据模型之后,django会自动生成一套数据库抽象API,可以让你执行增删改查操作。这篇文档阐述了如何使用这些API。关于所有模型检索选项详细内容,请见数据模型参考。...它可以含有零个、一个或者多个过滤器,过滤器根据所给参数限制查询结果范围。在sql角度,QuerySet和SELECT命令等价,过滤器是像WHERE和LIMIT一样限制子句。...限制查询范围 可以用 python 数组切片语法来限制你 QuerySet 得到一部分结果。它等价于SQL中 LIMIT 和 OFFSET 。...QuerySet 第一次运行时,会执行数据库查询,接下来 Django 就在 QuerySet 缓存中保存查询结果,并根据请求返回这些结果(比如,后面再次调用这个 QuerySet 时候)。...最上面的 models 为例,一个 Entry 对象 e 能通过 blog 属性获得相关联 Blog 对象: e.blog。

4.3K20
  • Django篇(二)

    Q对象 以上我们都是单个条件进行查询,那如果多个条件呢? 我们可以在上面获取对象再次进行筛选,也就是注意中说那句话,但是很麻烦。 因此Django为我们提供了Q模块来帮助我们多条件查询。...count函数 查询所有人数目也可以这样写 student.objects.all().count() 注意:当返回值类型为QuerySet类型时,我们称他为一个查询,可以再次进行以上任何操作。...2、缓存 当我们使用同一个查询时候,只有第一次是执行到数据库,然后把结果储存起来,当我们再次使用这个查询时候,就会调用我们缓存中数据。...查询相当于一个列表,我们取值可以遍历取出,也可以进行下表或者切片取出。 当我们对一个查询进行切片或下标查询,会返回一个新查询。 不同是我们切片不允许为负值。 判断一个查询是否有数据。...1、过滤查询,比如你查询全部数据,我只让你返回前十条。 2、添加新方法,比如添加,修改可以封装在里面方面我们使用。

    1.4K20

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

    第一种方法是从整个查询生成统计值。比如,你想要计算所有在售书平均价钱。Django查询语法提供了一种方式描述所有图书集合。...annotate()子句返回结果是一个查询 (QuerySet);这个 QuerySet可以用任何QuerySet方法进行修改,包括 filter(), order_by(), 甚至是再次应用annotate...例如,我们可以查询所有出版商,并注上它们一共出了多少本书(注意我们如何用 ‘book’指定Publisher -> Book 外键反转关系): >>> from django.db.models import...例如,你想得到Django” 为书名开头图书作者总数: >>> from django.db.models import Count, Avg >>> Book.objects.filter(...但是第一个查询注解包含其该出版商发行所有图书总数;而第二个查询注解只包含出版过好书出版商所发行图书总数。 在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。

    1.6K30

    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 提供了一种基于用户提供参数过滤查询简单方法。...要按request对象过滤查询,只需覆盖该 FilterSet.qs属性。...如果传递了一个可调用对象,它将以 request 为唯一参数进行调用 。这允许您执行相同类型基于请求过滤,而无需求助于覆盖FilterSet....__可以再次使用Django 语法来支持查找转换。 例如:year__gte。 字段field_name和字段一起 lookup_expr 代表一个完整 Django 查找表达式。

    2.2K20

    django模型

    每个模型对 应数据库中唯一一张表 如何编写模型 模型:每个模型都用一个类表示,该类继承自django.db.models.Model。...过滤器基于所给参数限制查询结果。 从SQL 角度,查询和SELECT 语句等 价,过滤器是像WHERE 和LIMIT 一样限制子句。 你可以从模型管理器那里取得查询。...查询参数(上面函数定义中**kwargs)需要满足特定格式,下面字段查询一节中会提 到 使用过滤器获取特定对象示例 要获取年份为2006所有文章查询,可以使用filter()方法: Entry.objects.filter...最后结果仍然是一个查询,它包含标题”What“开 头、发布日期在2005年1月30日至当天之间所有记录 过滤查询是独立 每次你筛选一个查询,得到都是全新另一个查询,它和之前查询之间没有任何绑...你可以将过滤器保持一整 天,直到查询 需要求值时,Django 才会真正运行这个查询

    3.1K20

    查询 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。

    1K40

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

    本文从Django官方文档总结而来,将聚合主要用法和查询常见方法做一归纳。 聚合 1....(括号里面有参数),后两者是不返回查询方法 。...发现aggregate 和 annotate用法区别了吗,再次举例如下(在聚合函数中指定聚合字段时,Django 允许你使用同样 双下划线 表示关联关系,): >>> from django.db.models...,但只有作者名称和average_rating 注解会返回在输出结果中 4.查询(QuerySet)API 查询 本质上,可以创建、过滤、切片和传递查询而不用真实操作数据库。...可以通过迭代、切片、序列化/缓存、repr()、len()、list()、bool() 1)返回新查询方法 filter(): 返回一个新QuerySet,包含与给定查询参数匹配对象。

    1.5K20

    Django 数据统计查询

    但是,有时你会需要处理一些有关对象集合统计。本文描述如何使用 Django 查询来处理统计。 本文我们将使用以下模型。...annotate() 每个参数代表一个统计。例如,要计算每本书作者人数: 生成查询集中每一个项目的统计 第二种方法是为 查询 中每个独立对象生成统计。...例如要统计书名 "Django" 开头书: >>> Book.objects.filter(name__startswith="Django").annotate(num_authors=Count...例如要统计书名 "Django" 开头平均价格: >>> Book.objects.filter(name__startswith="Django").aggregate(Avg('price...第一个查询中统计先于过滤器,所以过滤器对统计没有作用。而第二个查询过滤器先于统计,所以统计对象是已经过滤。 order_by() 统计可以作为排序基础。

    2.3K20

    Django—模型

    上去 3.字段查询 实现sql中where功能,调用过滤器filter()、exclude()、get(),下面filter()为例。 通过"属性名_id"表示外键对应对象id值。...4.查询 查询表示从数据库中获取对象集合,在管理器上调用某些过滤器方法会返回查询查询可以含有零个、一个或多个过滤器。...过滤器基于所给参数限制查询结果,从Sql角度,查询和select语句等价,过滤器像where和limit子句。 返回查询过滤器如下: all():返回所有数据。...缓存:使用同一个查询,第一次使用时会发生数据库查询,然后把结果缓存下来,再次使用这个查询时会使用缓存数据。 查询缓存 每个查询都包含一个缓存来最小化对数据库访问。...在新建查询集中,缓存为空,首次对查询求值时,会发生数据库查询django会将查询结果存在查询缓存中,并返回请求结果,接下来对查询求值将重用缓存中结果。

    6.1K21

    Django QuerySet查询原理及代码实例

    一 概念 DjangoORM中存在查询概念。 查询,也称查询结果、QuerySet,表示从数据库中获取对象集合。...当调用如下过滤器方法时,Django会返回查询(而不是简单列表): all():返回所有数据。 filter():返回满足条件数据。 exclude():返回满足条件之外数据。...对查询可以再次调用过滤器进行过滤,也就意味着查询可以含有零个、一个或多个过滤器。过滤器基于所给参数限制查询结果。...从SQL角度讲,查询与select语句等价,过滤器像where、limit、order by子句。...(book.btitle) 2)缓存   使用同一个查询,第一次使用时会发生数据库查询,然后Django会把结果缓存下来,再次使用这个查询时会使用缓存数据,减少了数据库查询次数。

    1.4K21

    Django模型model

    : 根据对象类型生成数据库表结构 将对象、列表操作,转换为sql语句 将sql查询结果转换为对象、列表 Django模型包含存储数据字段和约束,对应着数据库中唯一表 ORM.png 2....模型类中字段选项 通过字段选项,可以实现对字段约束 在字段对象时通过关键字参数指定 null:如果为True,Django 将空值NULL 存储到数据库中,默认值是 False blank:如果为True...模型类查询 查询表示从数据库中获取对象集合 查询可以含有零个、一个或多个过滤过滤器基于所给参数限制查询结果 从Sql角度,查询和select语句等价,过滤器像where和limit子句...接下来主要讨论如下知识点 查询 字段查询:比较运算符,F对象,Q对象(1)模型类查询集合 在管理器上调用过滤器方法会返回查询 查询经过过滤器筛选后返回新查询,因此可以写成链式过滤 惰性执行:...创建查询不会带来任何数据库访问,直到调用数据时,才会访问数据库 何时对查询求值:迭代,序列化,与if合用 返回查询方法,称为过滤器,管理器对象方法有all()、filter()、exclude

    13310

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

    过滤条件表达语法如下: 属性名称__比较运算符=值 # 属性名称和比较运算符间使用两个下划线,所以属性名不能包括多个下划线 查询编号为1图书 查询书名包含'湖'图书 查询书名'部'结尾图书...查询,也称查询结果、QuerySet,表示从数据库中获取对象集合。 当调用如下过滤器方法时,Django会返回查询(而不是简单列表): all():返回所有数据。...对查询可以再次调用过滤器进行过滤,如 >>> books = BookInfo.objects.filter(readcount__gt=30).order_by('pub_date') >>> books...过滤器基于所给参数限制查询结果。 从SQL角度讲,查询与select语句等价,过滤器像where、limit、order by子句。...使用同一个查询,第一次使用时会发生数据库查询,然后Django会把结果缓存下来,再次使用这个查询时会使用缓存数据,减少了数据库查询次数。

    1.9K40

    Django中数据库相关操作

    QuerySet 1 概念 DjangoORM中存在查询概念。...查询,也称查询结果、QuerySet,表示从数据库中获取对象集合。 当调用如下过滤器方法时,Django会返回查询(而不是简单列表): all():返回所有数据。...对查询可以再次调用过滤器进行过滤,如 BookInfo.objects.filter(bread__gt=30).order_by('bpub_date') 也就意味着查询可以含有零个、一个或多个过滤器...过滤器基于所给参数限制查询结果。 从SQL角度讲,查询与select语句等价,过滤器像where、limit、order by子句。...,第一次使用时会发生数据库查询,然后Django会把结果缓存下来,再次使用这个查询时会使用缓存数据,减少了数据库查询次数。

    2.2K50

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

    的确,大多数来自Django开发新手 问题是如何能使得通用视图使用范围更广。...然而,model参数并不是唯一能够指明视图要基于哪个对象进行操作方法 – 你同样可以使用queryset参数来指定一个对象列表: from django.views.generic import DetailView...然而,通过使用queryset来定义一个过滤对象列表,你可以更加详细 了解哪些对象将会被显示视图中(参见执行查询来获取更多关于查询对象更对信息,以及参见 基于类视图参考来获取全部 细节)。...Book.objects.filter(publisher__name='Acme Publishing') template_name = 'books/acme_list.html' 注意,除了经过过滤之后查询...pk - 这个名字是DetailView用来查找主键默认名称,其中主键用于过滤查询

    1.4K40

    django_2

    要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象...Django有两种过滤器用于筛选记录: filter:返回符合筛选条件数据 exclude :返回不符合筛选条件数据 链式调用: 多个filter和exclude可以连接在一起查询 Person.objects.filter...概念:查询表示从数据库获取对象集合,查询可以有多个过滤器。...过滤器:过滤器就是一个函数,基于所给参数限制查询集结果,返回查询方法称为过滤器。 查询经过过滤器筛选后返回新查询,所以可以写成链式调用。...第二个参数是limit 懒查询/缓存 查询缓存:每个查询都包含一个缓存,来最小化对数据库访问 在新建查询集中,缓存首次为空,第一次对查询求值,会发生数据缓存,django会将查询出来数据做

    3.6K30

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

    聚合 Django数据库抽象API描述了使用Django查询来添加、删除、查询和修改单个对象方法。然而,有时需要根据一组对象聚合您想要获得值。...本主题指南介绍如何使用Django查询生成和返回聚合值。...例如,想计算所有在售图书平均价格。Django查询语法提供了一种描述所有藏书方法。 传递给聚合()参数描述了要计算聚合值。在此示例中,将计算Book模型上价格字段平均值。...例如,可以使用查询生成所有书籍注释列表。此列表标题Django”开头。...很难直观地理解ORM如何将复杂查询转换为SQL查询。因此,如果有疑问,请使用str(queryset.query)`检查SQL并编写大量测试。

    2K40

    Django学习笔记之Queryset高效使用

    本文我将重点介绍如何有效使用 Django ORM系统访问中到大型数据。...Djangoqueryset是惰性 Djangoqueryset对应于数据库若干记录(row),通过可选查询过滤。...要真正从数据库获得数据,你需要遍历queryset: for person in person_set: print(person.last_name) Djangoqueryset是具有cache...这些model会保存在queryset内置cache中,这样如果你再次遍历这个queryset,你不需要重复运行通用查询。...如果查询很大的话,if 语句是个问题 如前所述,查询缓存对于组合 if 语句和 for 语句是很强大,它允许在一个查询上进行有条件循环。然而对于很大查询,则不适合使用查询缓存。

    2.8K30

    Django相关知识点回顾

    从失败中获得成功。 沮丧和失败是成功两个最可靠垫脚石。 小闫语录: 有些人因为失败而一蹶不振,有些人却凭借失败积累经验在后期获得成功。失败并不可怕,如果你连面对勇气都没有,那么你真的不配成功。...{% empty %} # 遍历为空时逻辑 {% endfor %} 13.2.3模板过滤器 a) Jinja2模板过滤器使用 {{ 模板变量|过滤器(参数...)}} b) Django中模板过滤使用...{{ 模板变量|过滤器:参数 }} 注意:Django过滤器 :之后只能接收一个参数 13.3步骤 13.3.1数据库连接配置 flask: SQLAlCHEMY_DATABASE_URI='mysql...QuerySet(查询) exclude 查询条件 返回不满足条件所有数据 QuerySet(查询) order_by 排序字段 对查询结果进行排序 QuerySet(查询) aggregate...查询结果缓存 使用同一个查询时,只有在第一次使用查询时会进行数据库查询操作,然后Django框架就会把查询结果存起来,下一次再使用这个查询时,使用Django之前存储结果。

    10K51
    领券