首页
学习
活动
专区
圈层
工具
发布

Django中的QuerySet

一、QuerySet   查询集,类似一个列表,包含了满足查询条件的所有项。QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作。只有你查询的时候才真正的操作数据库。...意味着QuerySet是惰性执行的----即创建查询集不会带来任何的数据库访问,直到查询集需要求值的时候,Django才会真正运行这个查询。...stu_obj = models.Student.objects.filter(id=2) for i in stu_obj: print(i.name) 只有在(print(i.name))时才访问一次数据库... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。... count(): 返回数据库中匹配查询(QuerySet)的对象数量。

1.9K32

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

QuerySet QuerySet本身可以在不访问数据库的情况下构造、过滤、切片或复制和分配。只需要在需要从数据库检索数据或将数据保存到数据库时访问数据库。...有关拾取QuerySet的详细信息,请参阅下一节。在本节中,从数据库中读取结果非常重要。 repr()调用repr()时,将执行QuerySet。...Pickle序列化通常用作缓存的前奏。重新加载缓存的查询集时,希望结果存在并可用(从数据库读取可能需要一些时间,这违反了缓存的目的)。...这意味着当取消缓存QuerySet时,它包含缓存时的结果,而不是数据库中当前的结果。 如果只想提取将来从数据库中重新创建QuerySet所需的信息,请提取QuerySet的查询属性。...表达式可以是简单值、对模型(或任何相关模型)字段的引用,或计算与QuerySet中的对象相关的对象的聚合表达式(平均值、总和等)。

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

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

    使用管理器访问关联对象 默认情况下,在访问相关对象时(例如choice.poll),Django 并不使用相关对象的默认管理器,而是使用一个”朴素”管理器类的实例来访问。...调用自定义的查询集 虽然大多数标准查询集的方法可以从管理器中直接访问到,但是这是一个例子,访问了定义在自定义 查询集上的额外方法,如果你也在管理器上面实现了它们: class PersonQuerySet...创建管理器 * django 1.7 中新增 * 对于上面的例子,同一个方法需要在查询集 和 管理器上创建两份副本,作为替代,QuerySet.as_manager()可以创建一个管理器的实例,它拥有自定义查询集的方法...from_queryset classmethod from_queryset(queryset_class) 在进一步的使用中,你可能想创建一个自定义管理器和一个自定义查询集。...在这种情况下,Django 必须要能看到相关模型的所有对象,所以才能根据关联关系得到任何数据 。

    1.5K20

    Django中的模板相关

    如果所有路径下都没有找到,那么会抛出一个 TemplateDoesNotExist 的异常。 模板语法 模板中可以包含变量, Django 在渲染模板的时候,可以传递变量对应的值过去进行替换。...注意:不能通过中括号的形式访问字典和列表中的值,比如dict[‘key’]和list[1]是不支持的!...不同的是最后一个元素的下标是从0 开始。 forloop.first :是否是第一次遍历。 forloop.last :是否是最后一次遍历。...有时候一个变量访问的时候比较复杂,那么可以先把这个复杂的变量缓存到一个变量上,以后就可以直接使用这个变量就可以了。...当然如果通过硬编码的方式直接将这个 url 写死在里面也是可以的。但是这样对于以后项目维护可能不是一件好事。因此建议使用这种反转的方式来实现,类似于 django 中的 reverse 一样。

    1.8K40

    从入门到精通Django REST Framework-(五)

    GenericAPIView 是 Django REST Framework (DRF) 中的一个基础视图类,它继承自 APIView,并添加了一些常用的功能,特别是与数据库模型交互的功能。...核心详解请求数据的访问GenericAPIView 继承了 APIView 的所有功能,因此可以通过 request 对象访问请求数据:def post(self, request): # 访问请求体数据...对象查找(lookup_field 和 lookup_url_kwarg)这两个属性控制如何从 URL 中获取单个对象。lookup_field:模型中用于查找对象的字段名,默认为 'pk'。...中,首先调用父类方法应用配置的过滤器然后遍历所有查询参数,检查是否与模型字段匹配对于匹配的参数,构建过滤条件并应用到查询集最后序列化过滤后的查询集并返回响应使用示例假设 Book 模型有 title、...title=Django - 过滤标题包含 "Django" 的图书/api/books/?

    89610

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

    网站:http://python.usyiyi.cn/django/index.html 数据库访问优化 Django的数据库层提供了很多方法来帮助开发者充分的利用他们的数据库。...要小心使用你自定义的属性 —— 实现所需的缓存取决于你,例如使用cached_property装饰符。 使用with模板标签 要利用QuerySet的缓存行为,你或许需要使用with模板标签。...一次性检索你需要的任何东西 在不同的位置多次访问数据库,一次获取一个数据集,通常来说不如在一次查询中获取它们更高效。如果你在一个循环中执行查询,这尤其重要。...不要不分析数据库就盲目使用延迟字段,因为数据库必须从磁盘中读取大多数非text和VARCHAR数据,在结果中作为单独的一行,即使其中的列很少。...{{ emails|length }}调用了QuerySet.len()方法,填充了缓存的剩余部分,而且并没有执行另一次查询。 for循环的迭代器访问了已经缓存的数据。

    1.6K30

    【Django】Django ORM 学习笔记

    通过使用 ORM,我们只需要操作 Author 和 Blog 对象,而不用操作相关的数据库表。这里主要介绍一下 Django ORM 的相关使用。...从数据库中查询出来的结果一般是一个集合,这个集合称为 QuerySet。...QuerySet exclude(**kwargs) - 获得不满足查询条件的 QuerySet get(**kwargs) — 从数据库中获得一个匹配的结果(一个实例),如果没有匹配结果或者匹配结果大于一个都会报错...len 函数 list: 对查询集调用 list() 方法强制求值 bool:测试一个查询集的布尔值,例如使用bool(), or, and 或者 if 语句都将导致查询集的求值 缓存 每个 QuerySet...当首次对 QuerySet 的所有实例进行求值时,会将查询结果保存到 QuerySet 的缓冲中。当再访问该 QuerySet 时,会直接从缓冲中取数据。

    2.7K20

    Django中数据库的相关操作

    .多对应的模型类中的关系类属性名 例: h = HeroInfo.objects.get(id=1) h.hbook 访问一对应的模型类关联对象的id语法: 多对应的模型类对象.关联类属性_id 例:...QuerySet 1 概念 Django的ORM中存在查询集的概念。...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。...过滤器基于所给的参数限制查询的结果。 从SQL的角度讲,查询集与select语句等价,过滤器像where、limit、order by子句。...2 两大特性 1)惰性执行 创建查询集不会访问数据库,直到调用数据时,才会访问数据库,调用数据的情况包括迭代、序列化、与if合用 例如,当执行如下语句时,并未进行数据库查询,只是创建了一个查询集qs qs

    2.9K50

    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 提供了一种基于用户提供的参数过滤查询集的简单方法。...自定义过滤字段 Filter.method 您可以通过指定 method 执行过滤来控制过滤器的行为。在方法参考中查看更多信息。...请注意,您可以访问过滤器集的属性,例如 request. class F(django_filters.FilterSet): username = CharFilter(method='my_custom_filter...您可以使用 Django 的__语法遍历“关系路径”来过滤相关模型上的字段。 例如:manufacturer__name。 lookup_expr: 过滤时使用的字段查找。...类中fields序列中的项目Meta可能包括“关系路径”,使用 Django 的__语法过滤相关模型上的字段: class ProductFilter(django_filters.FilterSet)

    2.8K20

    Django-官网查询部分翻译(1.11版本文档)-QuerySet-字段查找-06

    (ORM)中,数据库与 python 对象的映射关系十分形象,一个表模型类(class)即代表一张表,实例化出一个对象即代表一条数据记录 创建一个对象(一条数据记录) 在 django 中要想创建一个数据对象...Retrieving objects 查出对象(QuerySet) 从数据库中查询对象,通过 表模型类的 Manager 管理器 来构造一个 QuerySet 。...通常来说,QuerySet 的结果只会在你 “访问” 它们的时候才会从数据库获取,当你执行时,QuerySet 会通过访问数据库来取值(When you do, the QuerySet is evaluated...缓存中,并返回查询出来的结果集。...,如果 Entry 对应的表中没有任何对象符合 主键 是 1,那么 django 将会报错:Entry.DoesNotExist。

    3.4K20

    Django 2.0 新特性 转

    django.contrib.auth用户认证 PBKDF2密码哈希默认的迭代次数从36000增加到100000。...方法,支持PostGIS和SpatiaLite; 所有从GeoJSON导入的GEOSGeometry拥有SRID集合; 添加OSMWidget.default_zoom属性,用于自定义地图的默认缩放级别...()现在接收可选的字典类型关键字参数; QuerySet.values_list()新增named参数,用于获取命名的元组结果; 新的FilteredRelation类允许为查询集增加一个ON从句; Pagination...,现在它将返回配置在TEMPLATES中的多个DjangoTemplates引擎中的第一个,而不是弹出ImproperlyConfigured错误; 自定义模版标签现在接收强制关键字参数; Tests测试...QuerySet.reverse()和last()不能用于切片后的查询集 对切片后的查询集使用反转和获取最近对象的操作将弹出异常,如下所示: >>> Model.objects.all()[:2].reverse

    3.1K20

    Django项目知识点(四)

    渲染到对于的html页面 在类中有三个重要的访问函数方法 get 就是当我访问当url是,就是执行get的方法 def get(self, request): return render(...json的键值对,而不是列表 request.body就是form表单的数据 Queryset Django ORM用到三个类:Manager、QuerySet、Model。...QuerySet实例 就是从数据库根据自己要求拿数据的 连数据都那不出来,写啥视图 所以在编写queryset必须用django shell 调试 在model中,Django通过给Model增加一个objects...当我们需要对查询集(queryset)的某些字段进行计算或进行先分组再计算或排序, 我们就需要使用aggregate和annotate方法了。...这样就可以引用模型字段值并使用它们执行数据库操作,而无需实际将它们从数据库中拉出到Python内存中 说白了就是我从数据库拿东西,但是有些需要的字段没有,要通过绑定的外键的app的model拿。

    2.1K30

    37.Django1.11.6文档

    Django 不支持这种访问模型(从末尾进行切片),因为它不可能利用SQL 高效地实现。...(2)从管理器调用自定义QuerySet方法 虽然大多数标准QuerySet的方法可以从Manager中直接访问到,但是如果你需要将一些被定义到一个自定义QuerySet中的额外方法也在Manager...根据您的需求,包含相关字段的自定义用户模型可能是您更好的选择,但是,与项目应用程序中的默认用户模型的现有关系可能有助于额外的数据库加载。...get_group_permissions(user_obj, obj=None) 返回user_obj从其所属组的权限中获取的权限字符集。 ...Page.number 当前页的序号,从1开始。 Page.paginator 相关的Paginator对象。 会话 Django 提供对匿名会话的完全支持。

    26.6K80

    django-rest-framework框架学习

    在django中很著名的一个框架是django-rest-framework,帮我们减少了很多工作量,尤其在序列化与反序列化成我们需要的格式帮了我们省了很多事 在这里就记录一下个人的学习过程 django-rest-framework...://www.django-rest-framework.org/api-guide/serializers/ 创建serializers.py在其中实现序列化类 由于这个序列化是和我们的模型想对应的相关...在这里只需要继承相关的类,复写父类方法即可 # 学生列表 class StudentList(generics.ListCreateAPIView): queryset = Student.objects.all...请注意,使用超链接的API时,您需要确保双方的API意见和串行类设置查找字段,如果你需要使用一个自定义值 在get_queryset()中实现的是按照name查询的,因为很多时候客户端并不知道自己的id...是多少, serializer.data是对模型序列化成的字典,如果想拼成需要的格式,需要提前构造合适的字典,在用Response()方法帮我们序列化成json类型 在urls中自定义资源的url 在urls.py

    1.9K10
    领券