例:查询书名包含’传’的图书。...(peopleinfo__description__contains='八') >>> book QuerySet [传>, ]> 由一模型类条件查询多模型类数据...PeopleInfo: 王语嫣>, <PeopleInfo 6.查询集QuerySet 1 概念 Django的ORM中存在查询集的概念。...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。...使用同一个查询集,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。
和Template 此外,Django还有一个urls分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template URL控制器(路由层) 简单配置...将调用函数views.month_archive(request, '2005', '03') 有名分组 上面的示例使用简单的、没有命名的正则表达式组(通过圆括号)来捕获URL 中的值并以位置 参数传递给视图...P\d+)/$', book_achrive), 传参books_achrive(request, year=2012, month=12) 注意,有名分组相当于关键字传参,在views...DecimalField括号里的6代表最多6位数字,2表示必须有两位小数,1111.22这样的形式 一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行关于表记录的增删改查的操作...API 查询记录API(QuerySet) 从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet all(): 查询所有结果 Returns a new
目录 Django ORM 多表操作(二) 多对多操作常用API 分组查询 单表分组查询示例 多表分组查询练习 查询练习 ORM 事务 ORM 常见字段和参数 ORM常见字段 ORM 常见参数 choices...) book_obj.authors.remove() # 将某个特定的对象从被关联对象集合中去除。...分组查询一般会用到聚合函数,所以使用前要先从 django.db.models 引入 Avg,Max,Min,Count,Sum(首字母大写) from django.db.models import...取值,则返回值是 QuerySet 数据类型里面为一个个元组 注意:MySQL 中的 limit 相当于 ORM 中的 QuerySet 数据类型的切片,annotate 里面放聚合函数 values...元信息 ORM对应的类里面包含另一个Meta类,而Meta类封装了一些数据库的信息。
1.自定义管理器(Manager) 在语句Book.objects.all()中,objects是一个特殊的属性,通过它来查询数据库,它就是模型的一个Manager....每个Django模型至少有一个manager,你可以创建自定义manager以定制数据库的访问....(title__icontains='django').count() # 默认的查询方法依然可用 2 这样我们可以将经常使用的查询进行封装,就不必重复写代码了....例如,下面的模型有两个manger--一个返回所有对象,另一个仅返回作者是Roald Dahl的书 from django.db import models #首先,定义一个Manager的子类 class...同样重要的是,您要传递可以传递给模型方法的参数——这就是*args, **kwargs所做的事情。Django将不时扩展内置模型方法的功能,并添加新的参数。
可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...step“参数,Django 将执行数据库查询并返回一个列表。...对于大小写的敏感性,Django将根据数据库中的排序方式排序结果。...]> values()方法还有关键字参数**expressions,这些参数将传递给annotate(): >>> from django.db.models.functions import Lower...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。
一、orm查询 1.1配置测试脚本 为了方便我们测试SQL语句,我们需要配置一下tests.py文件,在这里测试我们的SQL语句,单独测试Django中的py文件都可以这样配置。....settings") import django django.setup() # 一定要等待测试脚本搭建完毕之后 才能导入django文件进行测试 from app01...(pk=3) publish_obj.delete() 1.2.4查询数据 queryset的filter()和对象的get()都是对数据的查询方法,括号内的条件相当于SQL语句中where后面的部分,...增加一条记录 方式一:直接给表里面的实际字段和主键值 models.Book.objects.create(name='三体',price=100,publisher_id=1) 方式二:传虚拟字段和数据对象...)#这里的publisher是出版社表的表名 更改一条记录 方式一:直接更改 models.Book.objects.filter(pk=5).update(publisher_id=4) 方式二:传虚拟字段和数据对象
前言 Django 的查询语法难以简单的表达复杂的 WHERE 子句,对于对于这种情况, Django 提供了 extra() 方法。...extra() 能在 QuerySet 生成的SQL从句中注入新子句,这样可以完成复制的查询。...django 查询的示例, where 传的是 list 类型参数: >>> PersonInfo.objects.all().extra(where=["age in (20, 21) and name...,加到 FROM 后面 如果我想把2个表的数据查询结果放到一张表 ?...django 查询的示例,table传list参数,可以是多个表名称,如:table=[‘yoyo_personinfo’] Card.objects.all().extra(tables=[‘yoyo_personinfo
目录 需求 创建一个Django项目 配置基础东西 连接mysql 使用Django_rest 解决跨域 建模(model里面写实体类) admin.py文件里面的创建 手动在后台管理系统里面添加相关数据...商品列表后台接口 序列器 view代码 url代码 实现分页(传limit offset) 实现根据字段进行排序和模糊搜索 商品分类查询 view代码 url代码 前端调用的书写 在分类查询的基础上面...,需要排序 根据生产厂商进行选择 view url 前段传参 商品的详情 view url 前端如何传参 查询的外键需要返回具体的name值,而不是id 第一种方法 第二种方法 实现用户的登录 用户的详情...(),name='product_list_by_category_manufacturer'), 前段传参 商品的详情 也就是根据列表数据的id值,进行查询数据库,将单个数据的详情进行返回给前端...传了参数,并且是put请求 ,就是新增 不传,直接调用,get请求,就是列表查询 序列器 class DeliveryAddressSerilizer(serializers.ModelSerializer
‘filename’ 指向的路径改为当前运行 Django 应用的用户可写的路径 配置三个记录器。 django,将所有信息传递给 console 处理程序。...优化ORM-excel导出函数export_teachers_excel(request): 在配置了日志或Django-Debug-Toolbar之后,我们可以查看一下之前将老师数据导出成Excel报表的视图函数执行情况...“N+1查询”),原本获取老师的数据只需要一条SQL,但是由于老师关联了学科,当我们查询到N条老师的数据时,Django的ORM框架又向数据库发出了N条SQL去查询老师所属学科的信息。...可以用QuerySet的only()方法来指定需要查询的属性,也可以用QuerySet的defer()方法来指定暂时不需要查询的属性,这样生成的SQL会通过投影操作来指定需要查询的列,从而改善查询性能,...('good_count'), bad=Avg('bad_count')) 可见,Django的ORM框架允许我们用面向对象的方式完成关系数据库中的分组和聚合查询。
正向查询(按字段):authors # 查询水浒传的作者性别 models.Book.objects.filter(name='水浒传').values('authors__sex') 反向查询(按表名...):book # 查询水浒传的作者性别 models.Author.objects.filter(book__name='水浒传').values('sex') 五.聚合查询与分组查询 聚合查询:aggregate...QuerySet种每一个对象都生成一个独立的统计值,相当于数据库种的group by 统计每一本书作者个数 from django.db.models import Count num=Book.objects.annotate...Q查询 F查询 现在位置的操作种,都是将模型字段与常量进行比较,但是,如果想将模型的一个字段与同一个模型的另一个字段进行比较该怎么办?...如:将read_num的数量乘以二 models.Book.objects.all().update(read_num=F('read_num')*2) Q查询 filter()等方法种的关键字参数查询都是通过逗号来实现
聚合 Django数据库抽象API描述了使用Django查询来添加、删除、查询和修改单个对象的方法。然而,有时需要根据一组对象聚合您想要获得的值。...第一种方法是从整个QuerySet生成摘要值。例如,想计算所有在售图书的平均价格。Django的查询语法提供了一种描述所有藏书的方法。 传递给聚合()的参数描述了要计算的聚合值。...但是,有时要聚合的值属于所查询模型的关联模型。 在聚合函数中指定聚合字段时,Django允许您在筛选相关字段时使用相同的双下划线符号。Django将处理需要检索和聚合相关值的任何表连接。...当注释()子句应用于查询时,将根据查询状态计算注释,直到请求的注释。这实际上意味着filter()和annotate()不是可互换的操作。 例如: 出版商A有两本评分为4和5的书。...第一个查询请求具有至少一本得分大于3的书的平均得分。第二个查询仅请求得分超过3的作者书的平均分数。 很难直观地理解ORM如何将复杂的查询集转换为SQL查询。
特别点 本文将翻译 django 官网的 模型层的 QuerySet 章节 文档版本:1.11 Making queries 进行查询 一旦你创建了 数据表模型类,django 会自动给你一些数据库抽象...API,让你可以创建、查询、更新、删除对象,下文将介绍如何使用这些API(以一个网页应用为例展开) 首先是创建表模型类 先分析一下他们的表关系,会有助于理解下面的内容 from django.db...把 add 方法解释一下(对象可以直接传,如果是值,要传元组?) ......新创建的 QuerySet 的缓存(cache)是空的,QuerySet 第一次取值执行(evaluatad)的时候进行数据库查询操作,Django 会将查询结果保存到 QuerySet 的 cache...cache print(queryset[5]) # 使用 cache 下面是一些可以将会整个取值(evaluated)的一些案例,可以将数据存到 cache 中(让后续使用 cache,减少数据库操作次数
查询类操作1)查询所有的结果,相当 sql 中的 select * fromlist = Test.objects.all()2)条件查询,filter 相关 sql 中的 where,用于过滤查询结果传多个参数...name=’test’).order_by(“-ctime”)6)多条件参数查询,传字典,构造查询条件data = Test.objects.filter(**query_dict).order_by(...delete()QuerySet相关Django中model查询出来的结构类型为QuerySet,本质是一个查询对象集。...1)将多个查询结果转换为字典列表// all()方法查询出来的是QuerySet,用values方法转成字典集data= Test.objects.all().values()data_dict_list...web开发接口的时候,要返回的是json数据,而django从DB查询出来的是对象集,可以考虑django-rest-framework 库的serializers类,具体可参考:Tutorial 1:
专栏系列:Django学习教程 导入文件 目标:导入部门清单excel,解析excel数据存储到数据库。...编写视图函数 导入逻辑: 1.根据标签定义的 name 获取文件对象 2.对象传递给openpyxl,由openpyxl读取文件的内容。...city_add函数: 1.如果是GET请求将form表单样式返回给模板。...2.如果是POST请求,1.将文件保存到启用的media的位置,2.将数据写入DB,3.转发给查询city_list查询最新数据并返回到模板。...(request, 'city_list.html', {'queryset': queryset}) class UpModelForm(BootstrapModelForm): # img
网站:http://python.usyiyi.cn/django/index.html 管理器 class Manager 管理器是一个接口,数据库查询操作通过它提供给django的模型。...自定义的管理器 方法可以返回你想要的任何数据,而不只是查询集。...=100) author = models.CharField(max_length=50) … Book.objects.all() 语句将返回数据库中所有的 Book 对象。...在这个简单的例子中,Book.objects.all()将返回数据库中所有的图书。而 Book.dahl_objects.all() 只返回作者是 Roald Dahl 的图书。...如果你重写了 get_queryset() 方法并且过滤掉了一些行数据,Django 将返回不正确的结果。不要这么做!
QuerySet QuerySet本身可以在不访问数据库的情况下构造、过滤、切片或复制和分配。只需要在需要从数据库检索数据或将数据保存到数据库时访问数据库。...切片未执行的QuerySet通常会返回另一个未执行的Query Set。但是,如果使用切片语法的step参数,Django将执行数据库查询并返回一个列表。...Django为此提供了count()方法。 Pickle 序列化 QuerySet 如果pickle以序列化QuerySet,这将强制在pickle序列化之前将所有结果加载到内存中。...为了实现这一点,大多数QuerySet方法返回一个新的查询集。本节稍后将详细介绍这些方法。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。
对处理首页的视图函数来说,虽然其处理的对象一个是文章,另一个是帖子,但是其处理的过程是非常类似的。首先是从数据库取出文章或者帖子列表,然后将这些数据传递给模板并渲染模板。...将 index 视图函数改写为类视图 针对这种从数据库中获取某个模型列表数据(比如这里的 Post 列表)的视图,Django 专门提供了一个 ListView 类视图。...将 model 指定为 Post,告诉 Django 我要获取的模型是 Post。 template_name。指定这个视图渲染的模板。 context_object_name。...指定获取的模型列表数据保存的变量名。这个变量会被传递给模板。...在 Django 中 URL 模式的配置方式就是通过 url 函数将 URL 和视图函数绑定。
执行这个视图的时候,self.object_list将包含视图正在操作的对象列表(通常是一个查询集,但不是必须)....方法: get_queryset():获取此视图的对象列表.必须是可迭代或者可以使查询集.默认返回queryset属性.可以通过重写该方法实现动态过滤.让这种方式能够工作的关键点,在于当类视图被调用时...属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg...context_object_name = 'employee_detail' #指定获取的模型列表数据保存的变量名。这个变量会被传递给模板。
题图:by thefolkpr0ject from Instagram 上篇文章讲解了 Django 如何创建模型,本文将继续讲解如何对模型进行增删改查操作。...1 前言 当我们建立好数据模型,Django 会自动为我们生成一套数据库接口相关的接口。这套接口称为 QuerySet API。为什么叫 QuerySet ?...() book.authors.add(aut) book.save() 3 查询对象 Django 提供在查询数据功能方面做了很多优化工作, 这让我们查询数据有千万种方法。...6 QuerySet 用法 前面讲到,使用 all(),filter() 查询多条数据,返回的结果是一个 QuerySet 对象。它不是个列表,但是可以使用 list() 将其转变为列表。...可惜的是 QuerySet 是不支持负查询。 但是也有替代方法 # 使用 reverse() 将 QuerySet 的顺序倒置下 # 再使用正查询, 下面的例子表示查询最后两条数据。