0922自我总结 django后台管理-admin 一.模型注册 admin.py 注册方式一: #在对于注册的app中的admin文件中导入模型然后注册模型 admin.site.register(导入的模型类...) 注册方式二该方法是Django1.7的版本新增的功能: from django.contrib import admin from blog.models import Blog #Blog模型的管理器...#listdisplay设置要显示在列表中的字段(id字段是Django模型的默认主键) list_display = ('id', 'caption', 'author', 'publish_time...设置显示外键字段 fk_fields = ('machine_room_id',) 2、筛选器 from django.contrib import admin from blog.models...一般ManyToManyField多对多字段用过滤器;标题等文本字段用搜索框;日期时间用分层筛选。 过滤器如果是外键需要遵循这样的语法:本表字段__外键表要显示的字段。
0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...', db_constraint=False, on_delete=models.DO_NOTHING, ) 1)关系字段放在Book表中(多的一方...models.DO_NOTHING为删除级联关系, models.CASCAD为级联关系,'SET_NULL'置空,SET_DEFAULT设为默认值 两者区别 models.SET关联表内容删了,关联的相关内容不会删除...models.CASCAD关联表内容删了,关联的相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系 例如Book、Author两表 authors = models.ManyToManyField
例如,想计算所有在售图书的平均价格。Django的查询语法提供了一种描述所有藏书的方法。 传递给聚合()的参数描述了要计算的聚合值。在此示例中,将计算Book模型上价格字段的平均值。...但是,有时要聚合的值属于所查询模型的关联模型。 在聚合函数中指定聚合字段时,Django允许您在筛选相关字段时使用相同的双下划线符号。Django将处理需要检索和聚合相关值的任何表连接。...应用于公共模型字段的任何过滤器()(或exclude())都将具有约束被认为是聚合的对象的效果。 当使用annotate()子句时,过滤器具有约束注释对象计算的效果。...过滤器优先于注释,因此过滤器限制了计算注释时要考虑的对象。 第一个查询请求具有至少一本得分大于3的书的平均得分。第二个查询仅请求得分超过3的作者书的平均分数。...很难直观地理解ORM如何将复杂的查询集转换为SQL查询。因此,如果有疑问,请使用str(queryset.query)`检查SQL并编写大量测试。
前言 在管理后台查询的时候,经常有需要查询包含某个内容,按时间段查询,或者商品价格大于多少,小于多少各种查询条件。 django-filter 过滤器专门解决这种查询的问题。...python:3.5、3.6、3.7、3.8 django:2.2、3.0、3.1 DRF : 3.10+ 简单入门 Django-filter 提供了一种基于用户提供的参数过滤查询集的简单方法。...None) return parent.filter(is_published=True) \ | parent.filter(author=author) 过滤相关查询集...您可以使用 Django 的__语法遍历“关系路径”来过滤相关模型上的字段。 例如:manufacturer__name。 lookup_expr: 过滤时使用的字段查找。...类中fields序列中的项目Meta可能包括“关系路径”,使用 Django 的__语法过滤相关模型上的字段: class ProductFilter(django_filters.FilterSet)
Django Form类定义中有一个 ModelChoiceField 对应的是Model 的外键,queryset 是返回一个查询集对象 例如,我有一个Form class BookForm(forms.Form...但是我想要传递books的id,就出现了问题。我们可以如下解决。...1、重写init方法并接受新的关键字 def __init__(self,*args,**kwargs): id = kwargs.pop('id',None) super(BookForm...BookForm() form.fields['books'].queryset = Books.objects.filter(id=1).all() 如果要设置默认值可以通过{initial={'id':1}的方法进行
过滤器聚合(Aggregation with Filter) 在 Django 2.0 之前,如果我们想要得到诸如用户总数和活跃用户总数之类的东西,我们不得不求助于条件表达式: from django.contrib.auth.models...2.0 中,添加了聚合函数的过滤器参数,使其更容易: from django.contrib.auth.models import User from django.db.models import...查询集的结果变为具名元组(QuerySet results as namedtuples) 我是一个 namedtuples 的粉丝,同时也是 Django 2.0 的 ORM 的粉丝。...外键索引(FK Indexes) 创建模型时,Django 会在所有外键上创建一个 B-Tree 索引,它的开销可能相当大,而且有时候并不很必要。...根据我们用这个模型的职能,我们可以设置db_index=False忽略 FK 索引,只保留唯一约束索引: class Membership(Model): group = ForeignKey(
有两种方式注册 1.1 方式一: from django.contrib import admin from blog.models import Blog #Blog模型的管理器 class...import admin from blog.models import Blog #Blog模型的管理器 @admin.register(Blog) class BlogAdmin(admin.ModelAdmin...import admin from app01.models import Book from django.utils.safestring import mark_safe #Blog模型的管理器...(id字段是Django模型的默认主键) list_display = ('name', 'publish', 'authors', 'pub_date','price') #...'pub_date') #筛选器 list_filter =('publish', 'author', ) #过滤器 search_fields =('name', 'net',
Django的模型进行数据库的查询操作的接口,Django应用的每个模型都拥有至少一个管理器 自定义管理器类主要用于两种情况 向管理器类中添加额外的方法创建管理器对象保存数据到数据库 class TestInfoManager...模型类的查询 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句...接下来主要讨论如下知识点 查询集 字段查询:比较运算符,F对象,Q对象(1)模型类查询集合 在管理器上调用过滤器方法会返回查询集 查询集经过过滤器筛选后返回新的查询集,因此可以写成链式过滤 惰性执行:...创建查询集不会带来任何数据库的访问,直到调用数据时,才会访问数据库 何时对查询集求值:迭代,序列化,与if合用 返回查询集的方法,称为过滤器,管理器对象方法有all()、filter()、exclude...,直接使用[0] 模型查询集的缓存 这构成了两个查询集,无法重用缓存,每次查询都会与数据库进行一次交互,增加了数据库的负载 print([e.title for e in Entry.objects.all
简介 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句 接下来主要讨论如下知识点...查询集 字段查询:比较运算符,F对象,Q对象 查询集 在管理器上调用过滤器方法会返回查询集 查询集经过过滤器筛选后返回新的查询集,因此可以写成链式过滤 惰性执行:创建查询集不会带来任何数据库的访问...,直到调用数据时,才会访问数据库 何时对查询集求值:迭代,序列化,与if合用 返回查询集的方法,称为过滤器 all() filter() exclude() order_by() values(...,[0:1].get()引发DoesNotExist异常 查询集的缓存 每个查询集都包含一个缓存来最小化对数据库的访问 在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中...')) django支持对F()对象使用算数运算 list.filter(bread__gte=F('bcommet') * 2) F()对象中还可以写作“模型类__列名”进行关联查询 list.filter
、每页显示几行、排序、默认可编辑的页面、外键字段、点击可以编辑的字段:list_display,list_per_page,ordering,list_editable,fk_fields,list_display_links...from django.contrib import admin from blog.models import Blog Blog模型的管理器 @admin.register(Blog) class...BlogAdmin(admin.ModelAdmin): #listdisplay设置要显示在列表中的字段(id字段是Django模型的默认主键) list_display = ('id', 'caption...设置显示外键字段 fk_fields = ('machine_room_id',) list_display_links = ('id', 'caption') 6、筛选和过滤: #筛选器...list_filter =('trouble', 'go_time', 'act_man__user_name', 'machine_room_id__machine_room_name') #过滤器
4.3 嵌套查找 4.4 参数说明 4.5 自定义过滤器 一、普通过滤 REST 框架的通用列表视图的默认行为是返回模型管理器的整个查询集。...通常,您希望 API 限制查询集返回的项目。 筛选子类的任何视图的查询集的最简单方法是重写该方法。...1.针对当前用户进行筛选 您可能希望筛选查询集,以确保仅返回与发出请求的当前经过身份验证的用户相关的结果。 为此,可以基于用户值进行筛选。...筛选初始查询集的最后一个示例是根据 url 中的查询参数确定初始查询集。...,REST 框架还包括对通用筛选后端的支持,这些后端允许您轻松构造复杂的搜索和筛选器。
执行查询 一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行增删改查的操作。这篇文档阐述了如何使用这些API。关于所有模型检索选项的详细内容,请见数据模型参考。...对 QuerySet 求值就意味着 Django 会访问数据库。想了解对查询集何时求值,请查看 何时对查询集求值 (When QuerySets are evaluated)....第二个过滤器在此基础上从这些 blogs 中检索与第二种 entry 也相关联的 blog。第二个过滤器选择的 entry 可能与第一个过滤器所选择的完全相同,也可能不同。...如果你要执行更复杂的查询(比如,实现筛选条件的 OR 关系),可以使用 Q 对象。 Q 对象(django.db.models.Q)是用来封装一组查询关键字的对象。...Django 的数据库映射来处理会非常复杂的话,你可以使用直接写 SQL 来完成。
{% empty %} # 遍历为空时的逻辑 {% endfor %} 13.2.3模板过滤器 a) Jinja2模板过滤器使用 {{ 模板变量|过滤器(参数...)}} b) Django中模板过滤器的使用...删除 查询对象->对象.delete() 或者: 模型类.objects.filter(...).delete() 查询 模型类.objects.查询函数 查询相关函数: 函数名称 参数 作用 返回值...all 无 查询模型类对应表格中的所有数据 QuerySet(查询集) get 查询条件 查询满足条件一条且只能有一条数据 模型类对象,查不到会报错DoesNotExist filter 查询条件 返回满足条件的所有数据...QuerySet(查询集) exclude 查询条件 返回不满足条件的所有数据 QuerySet(查询集) order_by 排序字段 对查询结果进行排序 QuerySet(查询集) aggregate...查询结果的缓存 使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来,下一次再使用这个查询集时,使用的Django之前存储的结果。
(id__gt=3) 不等于的运算符,使用exclude()过滤器。...() 由多到一的访问语法: 多对应的模型类对象.多对应的模型类中的关系类属性名 例: 比如查询英雄为1的下面的所有图书 h = HeroInfo.objects.get(id=1) h.hbook hbook...访问一对应的模型类关联对象的id语法(查询对应ID): 多对应的模型类对象.关联类属性_id 例 h = HeroInfo.objects.get(id=1) # HeroInfo是多的一方,hbook...是定义在一的一方 h.hbook_id 12> 关联查询 由多模型类条件查询一模型类数据: 语法如下: 关联模型类名小写__属性名__条件运算符=值 查询图书,要求图书英雄为"孙悟空" BookInfo.objects.filter...) 由一模型类条件查询多模型类数据: 语法如下: 一模型类关联属性名(FK对应属性名)__一模型类属性名__条件运算符=值 查询书名为“天龙八部”的所有英雄。
# 显示的名称 verbose_name = '公共' 在要修改名称的app下的init.py中键入如下代码: from django.apps import AppConfig # 要修改名称的...): 4.设置显示字段的各种:(看代码和注释) from django.contrib import admin from . import models # 模型的管理器 @admin.register...(models.Article) class BlogAdmin(admin.ModelAdmin): # listdisplay设置要显示在列表中的字段(id字段是Django模型的默认主键)...设置显示外键字段 fk_fields = () # 设置哪些字段可以点击进入编辑界面 list_display_links = ('name',) 还有搜索框 和过滤器 等,...重启项目、刷新页面后(已经变成我们刚才设置的): 目前,先这么多。django-admin 还有非常多强大的地方。 推荐第三方admin: 目前,最好用的第三方admin是 xadmin.
但是,有时你会需要处理一些有关对象的集合的统计。本文描述如何使用 Django 查询来处理统计。 本文我们将使用以下模型。...第二种方法是为 查询集 中每个独立的对象生成统计。...任何用于一般模型的 filter() (或 exclude() )也可与统计联用。 当与 annotate() 子句联用时,过滤器作用于被统计的对象上。...annotate() 和 filter() 子句的顺序 当使用同时包含 annotate() 和 filter() 子句的复杂查询时,要特别小心两种子句的顺序。...第一个查询中统计先于过滤器,所以过滤器对统计没有作用。而第二个查询过滤器先于统计,所以统计的对象是已经过滤过的。 order_by() 统计可以作为排序的基础。
在 Django 中,你可以使用单行查询来获取关联模型的数据。...这通常涉及使用查询集的 select_related 或 prefetch_related 方法,这两个方法允许你在一次数据库查询中获取关联模型的数据,而不是分开的多个查询。...下面是一些示例:1、问题背景在 Django 中,我们经常需要查询关联模型的数据。传统的方法是使用外键关系来获取关联模型的数据,这需要进行两次数据库查询。...为了提高效率,我们可以使用单行查询来获取关联模型的数据。...你可以根据自己的需求选择合适的方法。使用这些方法之一,我们可以在单行代码中获取关联模型的数据。这些方法可以帮助你优化数据库查询并减少不必要的查询次数,提高 Django 应用程序的性能。
) 2)模型类.objects.filter().delete() HeroInfo.objects.filter(id=14).delete() 查询集 QuerySet 1 概念 Django的ORM...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。...对查询集可以再次调用过滤器进行过滤,如 BookInfo.objects.filter(bread__gt=30).order_by('bpub_date') 也就意味着查询集可以含有零个、一个或多个过滤器...过滤器基于所给的参数限制查询的结果。 从SQL的角度讲,查询集与select语句等价,过滤器像where、limit、order by子句。...,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。
查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。..., ]> 也就意味着查询集可以含有零个、一个或多个过滤器。...过滤器基于所给的参数限制查询的结果。 从SQL的角度讲,查询集与select语句等价,过滤器像where、limit、order by子句。...使用同一个查询集,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。...对查询集进行切片后返回一个新的查询集,不会立即执行查询。
然而,你有时候会想要获取从一组对象导出的值或者是聚合一组对象。这份指南描述了通过Django查询来生成和返回聚合值的方法。 整篇指南我们都将引用以下模型。这些模型用来记录多个网上书店的库存。...第一种方法是从整个查询集生成统计值。比如,你想要计算所有在售书的平均价钱。Django的查询语法提供了一种方式描述所有图书的集合。...annotate() 的顺序 编写一个包含 annotate() 和 filter() 子句的复杂查询时,要特别注意作用于 QuerySet的子句的顺序。...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的图书总数。 在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...在第二个查询中,过滤器在注解之前,所以,在计算注解值时,过滤器就限制了参与运算的对象的范围。 order_by() 注解可以用来做为排序项。
领取专属 10元无门槛券
手把手带您无忧上云