一、QuerySet 查询集,类似一个列表,包含了满足查询条件的所有项。QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作。只有你查询的时候才真正的操作数据库。...意味着QuerySet是惰性执行的----即创建查询集不会带来任何的数据库访问,直到查询集需要求值的时候,Django才会真正运行这个查询。... exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。... count(): 返回数据库中匹配查询(QuerySet)的对象数量。
Django的Manager和QuerySet 要从数据库检索对象,需要通过模型类的 Manager 构建一个 QuerySet。...在Django中,模型的Manager提供了接口,它赋予了 Django 模型操作数据库的能力。默认情况下,Django 为每个模型类添加了一个名为 objects 的 Manager。...有关如何自定义Manager,在Django管理器中有详细说明。 QuerySet 一个 QuerySet 代表来自数据库中对象的一个集合。它可以有 0 个,1 个或者多个 filters。...在Django的文档中,明确的告诉了开发者,什么时候QuerySet被执行。因为这影响到SQL执行效率。...QuerySet 类具有两个可用于自省的公开属性: 可以返回QuerySet对象的QuerySet方法 前文所述的看起来做了3次SQL查询,实际上只有一次。
一般情况下,我们在写Django项目需要操作QuerySet时一些常用的方法已经满足我们日常大多数需求,比如get、filter、exclude、delete神马的感觉就已经无所不能了,但随着项目但业务逻辑越来越复杂...('time', 'black') 当你使用链式方法调用only时只有最后一个only内的参数会立即返回,其他参数都会被defer,注意这里only的覆盖性~ 5、create(**kwargs) 创建并保存对象...p = Blog.objects.order_by('title')[0] except IndexError: p = None 9、update(**kwargs) 用于更新一组数据...,但要注意,它不能更新外键, 不能更新切片过的queryset以及不能再被切片的set,用法如下: Entry.objects.filter(black=False).update(ip='0.0.0.0...答案在这里: django.models 的 on_delete参数,此参数有以下几个可选值: CASCADE:这就是delete()的默认选项,也就是关联删除 PROTECT:如果删除的model obj
>>> from django.contrib.auth.models import User >>> User.objects.none() QuerySet []> 以上就是本文的全部内容,如果觉得还不错的话
其实就是查询的意思。 所以,queryset 是什么?是查询结果的集合的意思。 我就不用那些标准的百度百科的回答了,咱直接上代码,从数据直接拿出来的数据来当例子,你就明白了。...我们用数据工厂平台的代码做演示,目前的models.py中的超链接表,存放数据为这样的,有俩个字段: 如图,俩个字段分别是link_name和link_url。...好然后我们用一段函数来把数据从中取出来并打印: 结果如下: 可以看到,直接从数据库用.all 或者.filter方法拿出来的 结果是queryset,也就是查询集合。...所以queryset的另一个特性就是可以像列表一样遍历和用下标定位具体内部元素: 遍历的具体子元素,都是一个个货真价实的数据记录哈。 别看我直接输出,就显示一个link_name的值。...此时我们得到的仍然是queryset,但结果中,却显示了所有字段。 这样我们用起来就更方便。为什么这么说呢? 因为我们可以把它外面再加上list() 变成我们python常用的格式了。
get_context_data(**kwargs): 返回显示对象的上下文数据,通过覆盖该方法返回额外的上下文 2.DetailView ?...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg...: model: queryset: context_object_name: pk_url_kwarg: 方法: get_queryset(): get_object(): form_valid():...显示用于编辑现有对象的表单的视图,重新显示具有验证错误信息的视图,并且保存对象.这里使用从对象模型自动生成的表单(除非手动制定表单类)....这种方式一般用于form需要更加精准的样式的时候,逐个元素逐个元素的编排到html中。 完成后可在页面上新增或修改项目信息。
本文我将重点介绍如何有效使用 Django ORM系统访问中到大型的数据集。...Django的queryset是惰性的 Django的queryset对应于数据库的若干记录(row),通过可选的查询来过滤。...要真正从数据库获得数据,你需要遍历queryset: for person in person_set: print(person.last_name) Django的queryset是具有cache...的 当你遍历queryset时,所有匹配的记录会从数据库获取,然后转换成Django的model。...queryset的cache是用于减少程序对数据库的查询,在通常的使用下会保证只有在需要的时候才会查询数据库。
get_context_data(**kwargs): 返回显示对象的上下文数据,通过覆盖该方法返回额外的上下文 2.DetailView ?...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg...显示用于创建对象的表单的视图,通过验证错误信息重新显示视图,并且保存对象....显示用于编辑现有对象的表单的视图,重新显示具有验证错误信息的视图,并且保存对象.这里使用从对象模型自动生成的表单(除非手动制定表单类)....这种方式一般用于form需要更加精准的样式的时候,逐个元素逐个元素的编排到html中。 完成后可在页面上新增或修改项目信息。
使用 Django 的模型,都是 django.db.models.Model 类的子类。 每个类将被转成数据库表。 每个字段由 django.db.models.Field 子类转成数据库的列。...模型之间的关系使用 ForeignKey 字段。 位置参数 related_name 用于引用关联的模型。 related_name 参数将用于创建反向关系。...('topic_pk')) queryset = self.topic.posts.order_by('created_at') return queryset ② 回帖...= 'post_pk' context_object_name = 'post' # 其他用户可以编辑所有帖子的问题 def get_queryset(self):...queryset = super().get_queryset() return queryset.filter(created_by=self.request.user) def
一、基础视图 (APIView)APIView 是 DRF 中所有视图的基类,继承自 Django 的 View,并添加了 DRF 特有的功能(如认证、权限、限流等)。...属性名 说明 queryset 视图使用的基础查询集,用于获取模型实例...lookup_field 用于查询单个对象的模型字段,默认值为 'pk'(主键)。若使用自定义字段,需确保视图和序列化器同步设置。...lookup_url_kwargURL 中用于对象查找的关键字参数,默认与 lookup_field 相同。需与 URL 配置中的参数名保持一致。...get_paginated_response(self, data):返回分页格式的响应对象,配合分页功能使用。您正在阅读的是《Django从入门到实战》专栏!关注不迷路~
后面会详细讲解Django每一部分的使用方式和API了 本节内容 内置视图处理对象的定义 内置视图处理对象的使用 源代码分析 1....常规情况下,对应页面中要展示数据列表的视图,通过继承Django的django.views.generic.ListView对象来实现,页面中要展示数据信息的视图,通过继承Django的django.views.generic.DetailView...DetailView和ResultView中的要查询的数据,同样也是通过主键编号进行查询的,默认的变量名称是pk,所以在路由中要进行如下的修改配置,才可以正常使用 改造polls/urls.py路由模块...= 'pk' query_pk_and_slug = False .........我们可以在源代码中,看到各种操作的一些信息,官方注释用于使用对象数据来渲染详细信息页面的视图对象,继承的父类中,也定义了各种属性字段用于控制单个对象数据的展示操作 以上两个视图类,都间接继承了View
') exclude 取反查询 exclude() 方法用于查询不符合条件的数据,返回的是 QuerySet 类型数据,类似于 list,里面放的是不满足条件的模型类的对象,可用索引下标取出模型类的对象...# 查询符合条件数据的数量 return HttpResponse('数据查询成功') exists 判断 exists() 方法用于判断查询的结果 QuerySet 列表里是否有数据...,字段名和数据都能够获取到 values_list查询返回的结果是列表套元组的形式,只返回数据 distinct 去重 distinct() 方法用于对数据进行去重,返回的是 QuerySet 类型数据...对象.delete() 返回值:元组,第一个元素为受影响的行数 book_obj=models.Book.objects.filter(pk=8).first().delete() 方式二:使用 QuerySet...的行为,也就是删除一个对象时也会删除与它相关联的外键对象; delete() 方法是 QuerySet 数据类型的方法,但并不适用于 Manager 本身。
常规的view类,优点: * 提供了更好用的request对象,不同于普通的django HttpRequest更好用。...1) API策略属性 以下的API策略属性应用于APIView,控制视图的策略: renderer_classes: 渲染器类 parser_classes: 解释器类 authentication_classes...1)属性 基本属性: queryset: 用于返回query对象集合,也可以使用get_queryset()方法。...serializer_class: 序列化器类,应该用于输入进行验证和反序列化,并用于序列化输出。...lookup_field: 模型的字段应该用于执行对象查找个别的模型实例 lookup_url_kwarg:URL应该用于对象查找关键字参数 分页属性: pagination_class: 用于返回一个分页列表视图的分页类
切片未执行的QuerySet通常会返回另一个未执行的Query Set。但是,如果使用切片语法的step参数,Django将执行数据库查询并返回一个列表。...Django为此提供了count()方法。 Pickle 序列化 QuerySet 如果pickle以序列化QuerySet,这将强制在pickle序列化之前将所有结果加载到内存中。...这意味着当取消缓存QuerySet时,它包含缓存时的结果,而不是数据库中当前的结果。 如果只想提取将来从数据库中重新创建QuerySet所需的信息,请提取QuerySet的查询属性。...QuerySet类具有以下公共属性,可用于内省: 有序 True如果QuerySet是有序的–有一个order_by()子句或模型的默认排序。否则,这是错误的。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。
对应规则的说明见 使用视图集简化代码),将其在路由器中注册后,django-restframework 自动会自动为我们生成对应的 API 接口。...= Post.objects.all() permission_classes = [AllowAny] 现在,路由会自动增加一个 /posts/:pk/ 的 URL 模式,其中 pk 为文章的...get_object 方法通常情况下依据以下两点来筛选出单个资源对象: get_queryset 方法(或者 queryset 属性,get_queryset 方法返回的值优先)返回的资源列表对象。...lookup_field 属性指定的资源筛选字段(默认为 pk)。django-rest-framework 以该字段的值从 get_queryset 返回的资源列表中筛选出单个资源对象。...类似于视图集类的 queryset 属性和 get_queryset 方法的关系, serializer_class 属性的值也可以通过 get_serializer_class 方法返回的值覆盖,因此我们可以根据不同的
模板间的关系时的开发网页减少大量的冗余内容。 后端使用模板,多用于开发访问量较小的后台管理系统。 模板语法 模版文件中使用的variables会被上下文字典中的对应的key的值所替代。..., 'count') # 标签 # article_tag_queryset = user_articles.values('tag__pk').annotate(count=Count...('pk')).values('tag__title', 'count') 这个计算出来是一个{'None': 6} 把None做了一个分类,下面分组方式就是一个[]的queryset。...=Count('article__pk')).values('title', 'count') print(article_tag_queryset) ### article_archive_queryset...什么时候继承,什么时候包含:继承是框架,包含是插拔插件,包含是对继承的补充。继承局限更强,包含可跨继承。比如说,一个父模板,所有的子模版都是在继承父类的基础上修改覆盖。
开发环境 django 1.11 DetailView 的相关源码 # .....\Lib\site-packages\django\views\generic\dates.py class DateDetailView(SingleObjectTemplateResponseMixin...pk is not None: queryset = queryset.filter(pk=pk) # Next, try looking up by slug...获取对应文章的信息 """ # 文章详情增加缓存 pk = self.kwargs.get(self.pk_url_kwarg) # 获取主键...obj = cache.get("article_obj_%s" % pk) # 获取该主键的缓存 if not obj: # 如果没有就 obj = super
GET 用于从服务器请求数据,每当点击了一个链接或者直接在浏览器中输入一个网址时,就创建了一个 GET 请求。 POST 用于想更改服务器上的数据,每次发送数据给服务器都会导致资源状态变化。...Django 使用 CSRF Token 保护所有的 POST 请求,这是避免外部站点或者应用程序向服务器的应用程序提交数据的安全措施。...(self): self.board = get_object_or_404(Board, pk=self.kwargs.get('pk')) queryset = self.board.topics.order_by...('-last_updated').annotate(replies=Count('posts') - 1) return queryset ③ 新建话题 Django 内置的视图装饰器...from django.contrib.auth.decorators import login_required @login_required def new_topic(request, pk):
然而,任何一个承受高负载的成熟项目都不可避免地需要进行优化。在本文中,我想谈谈优化Web项目代码的五种常用方法。虽然本文是以Django为例,但其他框架和语言的优化原则也是类似的。...,Django中的查询是惰性的。...1.2 仅提供相关的数据 默认情况下,Django会从数据库中提取所有字段。但是,当表有很多列很多行的时候,告诉Django提取哪些特定的字段就非常有意义了,这样就不会花时间去获取根本用不到的信息。...第一个用于指定哪些字段不要加载,第二个用于指定只加载哪些字段。...对响应时间的进一步优化可以通过使用缓存来实现,但是我不会在这篇文章中介绍这个。 结论 性能优化是一个分析和发现的过程。 没有哪个硬性规定能适用于所有情况,因为每个项目都有自己的流程和瓶颈。
0909自我总结 drf框架中所有视图及用法 一.drf框架中的所有视图类 from django.views import View from rest_framework import views,...generics, mixins, viewsets 最基础:django自带的views类 drf框架中最基础的视图类:views.APIView drf框架中工具视图:generics GenericAPIView...self.get_queryset() :获取所有 self.get_object() :获取根据pk获取单个 self.get_serializer(*args, **kwargs):获取指定 常用的几个参数...data:用于返序列化传参 many:获取多个序列化对象 instance:如果有后面save执行更新方法,没有执行创建方法 partial:为True可以进行局部字段修改,默认为False为所有字段修改...使用这些方法的重要前提必须要 queryset serializer_class 如果我们要使用get_object()必须前端传给我们一个pk 四.mixins使用 mixins是在generics