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

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

使用过滤器获取特定对象 all()方法返回的结果集中包含全部对象,但是更普遍的情况是你需要获取完整集合的一个子集。 要创建这样一个子集,需要精炼上面的结果集,增加一些过滤器作为条件。...一般来说,对 QuerySet 切片会返回新的 QuerySet – 这个过程中不会对运行查询。不过也有例外,如果你在切片时使用了 “step” 参数,查询集就会被求值,就在数据库中运行查询。...实际上比较的是两个 model 的主键值。...Django 会自动比较主键的值,而不管他们的名称是什么。...本质上来说,INSTALLED_APPS 的作用之一就是确认 Django 完整的 model 范围。 在关联对象上的查询 包含关联对象的查询与包含普通字段值的查询都遵循相同的规则。

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

    DRF视图详解:从基础视图到通用视图实践指南

    get_queryset() 方法,可以实现动态过滤查询集,例如只返回当前登录用户的数据:def get_queryset(self): # 只返回当前用户创建的数据 return Student.objects.filter...通常需要设置此属性或重写 get_queryset() 方法。注意直接访问 self.queryset 会导致结果缓存,应优先使用 get_queryset() 方法。...数据查询相关方法get_queryset(self):返回视图使用的查询集,是获取数据的主要入口。...默认返回 queryset 属性定义的查询集,可重写以实现动态过滤(如返回当前用户的数据)def get_queryset(self): return self.request.user.articles.all...filter_queryset(self, queryset):应用过滤后端对查询集进行过滤,返回处理后的查询集。

    31810

    Django之QuerySet详解

    换句话说,用order_by()方法对QuerySet对象进行操作会返回一个扩大版的新QuerySet对象。因此,使用多值字段对结果进行排序时要格外小心。 没有方法指定排序是否考虑大小写。...21. using() using(alias) 如果正在使用多个数据库,这个方法用于指定在哪个数据库上查询QuerySet。方法的唯一参数是数据库的别名,定义在DATABASES。...在这种情况下,应该限制查询在关联的上下文内部。 否则,可能导致完整性问题。...对于返回大量只需要访问一次的对象的QuerySet,这可以带来更好的性能,显著减少内存使用。 请注意,在已经提交了的iterator()上使用QuerySet会强制它再次提交数据库操作,进行重复查询。...earliest()和latest()可能会返回空日期的实例,可能需要过滤掉空值: Entry.objects.filter(pub_date__isnull=False).latest('pub_date

    3.7K20

    django-7-django模型系统

    TestFiled  DateFiled  AutoFiled(primary_key=True)自增,不指定主键会自动创建 在使用的时候何以设置DateField.auto_now每次自动保存对象的时候自动设置改字段为当前时间... 模型类上的管理器(class.objects)  queryset (惰性,,没有操作数据库)表示数据库中对象的集合,等同于select 语句   query 获取mysql 语句  first()...) 根据给定的条件获取过滤后的queryset,多个条件用','连接  exclude(**kwargs) 作用和filter相反,去除不符合条件的对象  多条件的or连接  from django.db.models...import Q  Q(age=1) | Q(age=0)  返回某个字段  values(*fileds) field指定字段,返回一个queryset,返回一个‘字典列表’  only(*fields...) 与values差不多,返回queryset,‘对象列表’,必须带上主键  defer(*field) 和only功能相反,用法一样,返回一个queryset,对象列表,排除  排序  order_by

    1.2K10

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

    想要得到这么一小部分对象,我们需要细化(约束)最初的 QuerySet ,增加过滤条件,细化 QuerySet 最常用的两种写法如下: filter(**kwargs) 返回一个符合你给出的查找参数(条件...),附加条件:pub_date 不是(exclude)今天或者将来的 --> 今天及今天之前的 第三个 QuerySet 是第一个集合的子集合(在第一个的条件上再加条件),附加条件:pub_date 是今天或者将来的...后续取值可以复用 QuerySet 的缓存结果。 # 下面的这两行代码会走两次数据库操作,很可能他们两次得到的数据是相同的。 # 为什么我们不避免它呢?...(use for introspection) ordered 如果 QuerySet 的查询结果是有序的,会返回 True,如果是无序的,会返回False db 将会用于执行查询语句的数据库 query...=False) 过滤字段 .none() 创建空的 QuerySet 调用 .none() 方法会创建一个空的 QuerySet ,里面不包含任何数据对象,并且在取值时也不会执行任何数据库操作(是 EmptyQuerySet

    3.4K20

    编写自己的dapper lambda扩展-使用篇

    这是个人业余的开源小项目,如果大家有更好的实现方式和好的建议欢迎拍砖 本项目已经在github上开源了:Sikiro.DapperLambdaExtension.MsSql 去年写了《整理自己的.net...工具库》,里面提供的源码重新发布到了github并用新的项目名Sikiro.Tookits 这两个项目都发布到Nuget上了,可以在Nuget搜索Sikiro可以全部查看到 另外该项目会用到一些表达式树的知识...,如果有兴趣的朋友可以先去了解,我之前也写过一篇简单的文章《表达式树的解析.》...您可以根据条件来删除数据 con.CommandSet().Where(a => a.Email == "287245177@qq.com").Delete() QUERY GET 获取过滤条件的一条数据...fengshuzhen", UserStatus = 1, UserType = 1, Password = "asdasdad" }); }); 最后来一个完整的

    1.3K20

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

    它是 DRF 中通用视图和视图集的基础,提供了查询、序列化、分页等常用操作的标准实现。本质上它是 DRF 中所有通用视图(如 ListAPIView、RetrieveAPIView 等)的基础。二....def get_serializer_class(self): """根据请求方法和用户角色返回不同的序列化器""" # 管理员使用完整序列化器 if self.request.user.is_staff...会应用所有配置的过滤器 queryset = self.filter_queryset(self.get_queryset()) serializer = self.get_serializer...GET 请求时,视图调用 get 方法get 方法首先调用 self.get_queryset() 获取基础查询集然后调用 self.filter_queryset() 应用过滤在 filter_queryset...中,首先调用父类方法应用配置的过滤器然后遍历所有查询参数,检查是否与模型字段匹配对于匹配的参数,构建过滤条件并应用到查询集最后序列化过滤后的查询集并返回响应使用示例假设 Book 模型有 title、

    96610

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

    在数据库中而不是Python中做数据库的工作 比如: 在最基础的层面上,使用过滤器和反向过滤器对数据库进行过滤。 使用F 表达式在相同模型中基于其他字段进行过滤。 使用数据库中的注解和聚合。...如果记录中返回了成百上千个对象,代价是非常大的。如果数据库运行在分布式服务器上,网络开销和延迟也是一大因素,代价会是它们的组合。...{% if emails %}的那一行调用了QuerySet.bool(),它导致user.emails.all()查询在数据库上执行,并且至少在第一行以一个ORM对象的形式返回。...如果没有任何结果,会返回False,反之为True。 {{ emails|length }}调用了QuerySet.len()方法,填充了缓存的剩余部分,而且并没有执行另一次查询。...直接使用外键的值 如果你仅仅需要外键当中的一个值,要使用对象上你已经取得的外键的值,而不是获取整个关联对象再得到它的主键。

    1.6K30

    DRF框架学习(三)

    1.2类视图的两个基类 1.2.1APIView 是View类的子类,在view类的基础上添加了一些额外的功能。...2.响应时可以统一返回Response类的对象 3.异常处理:如果视图中抛出了未处理异常,DRF框架会自动对异常进行处理,并且会把处理之后的错误信息返回给客户端。...Response类的对象: 1.传入原始相应数据(比如一个字典),Response会自动根据客户端请求头中 Accept将相应数据转换为对应的格式进行返回。默认是json格式。...1.2.2GenericAPIView 继承于APIView,是APIView的子类,在APIView的基础上添加操作序列化器和数据库查询的方法。封装的这些方法,我们可以直接使用。...其他功能: a)过滤 b)分页 补充知识点: 查询的时候我们想不根据主键pk查询,而是根据我们的需求查,那么可以根据修改 lookup_field(值改为我们要查询的字段的名称)的值来解决需求。

    1.5K20

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

    属性: model: 指定模型 tempalta_name:模板文件 queryset:指定一个经过过滤的对象列表,将取代model提供的值 context_object_name: 指定要在上下文中使用的变量的名称...方法: get_queryset():获取此视图的对象列表.必须是可迭代或者可以使查询集.默认返回queryset属性.可以通过重写该方法实现动态过滤.让这种方式能够工作的关键点,在于当类视图被调用时...,各种有用的对象被存储在self上,同request(self.request)一样,其中包含了从URLconf中获取到的位置参数(self.args)和关键字参数(self.kwargs)....方法: get_queryset():返回用来获取本视图显示对象的queryset.如果设置了queryset属性,get_queryset()默认返回它的值. get_object(queryset=...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg

    4.3K40

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

    如果你将你的视图实现为通用视图的子类,你就会发现这样能够更有效地编写你想要的代码,使用你自己的基于类或功能的视图。 在一些三方的应用中,有更多通用视图的示例,或者你可以自己按需编写。...要在你自己想要改变上下文的类中保持这一行为,你应该确保在超类中调用了get_context_data。如果没有任意两个类尝试定义相同的键,会返回异常的结果。...相当方便的是, ListView 有一个get_queryset() 方法来供我们重写。在之前,它只是返回一个queryset属性值,但是现在我们可以添加更多的逻辑。...让这种方式能够工作的关键点,在于当类视图被调用时,各种有用的对象被存储在self上;同request()(self.request)一样,其中包含了从URLconf中获取到的位置参数 (self.args...pk - 这个名字是DetailView用来查找主键的值的默认名称,其中主键用于过滤查询集。

    2.3K40

    django 1.8 官方文档翻译: 2-5-6 多数据库

    人工指定的数据库的优先级高于路由分配的数据库。 为QuerySet手动选择一个数据库 你可以在QuerySet“链”的任意节点上为QuerySet选择数据库 。...当保存在statement 2中发生时,p已经具有一个主键,Django 将尝试在新的数据库上使用该主键。...然而,如果p 的主键在second数据库上已经在使用second 数据库中的已经存在的对象将在p保存时被覆盖。 你可以用两种方法避免这种情况。首先,你可以清除实例的主键。...在两个数据库上具有相同的主键。...为了保持两个对象之间的关联,Django 需要知道关联对象的主键是合法的。如果主键存储在另外一个数据库上,判断一个主键的合法性不是很容易。

    2.2K20

    Django学习笔记:QuerySet API

    他的方法全部都是通过Python动态添加的方式,从QuerySet类中拷贝过来的。 所以我们如果想要学习ORM模型的查找操作,必须首先要学会QuerySet上的一些API的使用。...返回新的QuerySet的方法: 在使用QuerySet进行查找操作的时候,可以提供多种操作。比如过滤完后还要根据某个字段进行排序,那么这一系列的操作我们可以通过一个非常流畅的链式调用的方式进行。...那么以下将介绍在那些会返回新的QuerySet对象的方法。 filter:将满足条件的数据提取出来,返回一个新的QuerySet。具体的filter可以提供什么条件查询。请见查询操作章节。...,但是有些字段是不能过滤的,比如id,即使你过滤了,也会提取出来。...说明上面的QuerySet并没有真正的执行。 在以下情况下QuerySet会被转换为SQL语句执行: 迭代:在遍历QuerySet对象的时候,会首先先执行这个SQL语句,然后再把这个结果返回进行迭代。

    97620

    Django MVT之M

    更加完整的介绍参考Django 1.8.2 中文文档 字段选项 通过选项实现对字段的约束,常用选项如下: 选项 描述 default 字段默认值 primary_key 主键约束。...默认值是False,若为True,则该字段会成为模型的主键字段,一般作为AutoField的选项使用。 unique 唯一约束。默认值是False,如果为True, 这个字段在表中必须有唯一值。...all 返回模型类对应表格中的所有数据。 QuerySet对象 aggregate 无参数 filter 返回表中满足条件的数据。 QuerySet对象 参数为查询条件。...查询集(QuerySet对象) 调用all, filter, exclude, order_by这些函数会返回一个查询集(QuerySet对象),查询集有以下特性: 惰性查询:只有在实际使用查询集中的数据的时候才会发生对数据库的真正查询...# 1.自定义一个管理器类,这个类继承models.Manger类 class SchoolInfoManager(models.Manager): # 过滤父类方法返回的查询集来改变查询集

    1.5K10

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

    QuerySet QuerySet本身可以在不访问数据库的情况下构造、过滤、切片或复制和分配。只需要在需要从数据库检索数据或将数据保存到数据库时访问数据库。...切片未执行的QuerySet通常会返回另一个未执行的Query Set。但是,如果使用切片语法的step参数,Django将执行数据库查询并返回一个列表。...对执行的QuerySet进行切片也会返回一个列表。...len()调用len()时,将执行QuerySet。正如所期望的,这将返回结果列表的长度。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。

    2.7K10
    领券