可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...db:如果现在执行,则返回使用的数据库。 三、返回新QuerySets的API 以下的方法都将返回一个新的QuerySets。重点是加粗的几个API,其它的使用场景很少。...values() 返回包含对象具体值的字典的QuerySet values_list() 与values()类似,只是返回的是元组而不是字典。...7. values() values(fields, *expressions) 返回一个包含数据的字典的queryset,而不是模型实例。...如果为True,它表示返回的结果为单个值而不是元组。
一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行关于表记录的增删改查的操作。...,运行后得到的并不是一系列 model的实例化对象,而是一个可迭代的字典序列 values_list(*field): 它与values...2.aggregate(*args,**kwargs):通过对QuerySet进行计算,返回一个聚合值的字典,aggregate()中每个参数都可以指定一个包含在字典中的返回值。...如果你需要执行更复杂的查询(例如OR 语句),你可以使用Q 对象。 ?...(例如,遍历 QuerySet,在每个对象上调用 delete()方法),而不是使用 QuerySet 中的 delete()方法。
manager类,而不是自定义QuerySet类,一般的我们没有自定义QuerySet类的必要;django.db.models模块中的Model类,我们定义表的model时,就是继承它,它的功能很强大...一般而言,当对一个没有求值的QuerySet进行的运算,返回的是QuerySet、ValuesQuerySet、ValuesListQuerySet、Model实例时,一般不会立即查询数据库;反之,当返回的不是这些类型时...而values_list()跟values()相似,它返回的是一个ValuesListQuerySet,也类型于一个列表,不过它的元素不是字典,而是元组。...在代码1中,在遍历a前,先执行a对应的SQL,拿到数据后,然后再遍历a,而遍历过程中,每次都还要查询数据库获取关联表。...annotate相当于aggregate()和group by的结合,对每个group执行aggregate()函数。而单独的aggregate()并没有group by。
django提供两种方法使用原始sql进行查询:一种是使用Manager.raw()方法,进行原始查询并返回模型实例;另一种是完全避开模型层,直接执行自定义的sql语句。...进行原始查询 raw()方法用于原始的sql查询,并返回模型的实例: Manager.raw(raw_query, params=None, translations=None) 这个方法执行原始的sql...') 查询返回的Person对象是一个延迟的模型实例(请见 defer())。...通常,Python DB API会返回不带字段的结果,这意味着你需要以一个列表结束,而不是一个字典。...如果你不熟悉Python DB-API,注意cursor.execute()中的sql语句使用占位符“%s”,而不是直接在sql中添加参数。如果你使用它,下面的数据库会在必要时自动转义你的参数。
示例图如下: 所以我们如果想要学习ORM模型的查找操作,必须首先要学会QuerySet上的一些API的使用 QuerySet 21个常用的API filter filter:将满足条件的数据提取出来...默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典:...如果在values中没有传递任何参数,那么将会返回一个字典,字典中包含这个模型中所有的属性。...只不过返回的QuerySet中,存储的不是字典,而是元组。...这个字段跟values有点类似,只不过defer返回的不是字典,而是模型。
models本身没有什么需要多说的,Django 使用了一套直观的系统:一个模型类代表一张数据表,一个模型类的实例代表数据库表中的一行记录。 模型类的save方法可以插入,更新,删除数据。...那么是否可以查询数据呢?实际上由于“一个模型类的实例代表数据库表中的一行记录”,因此模型类的实例是不能起到查询数据的功能。 Manager 因此,我们要从数据库检索到数据,ORM就必须提供相应的方法。...people = models.Manager() # 自定义名为people的管理器 使用这个实例模型时, Person.objects 会产生一个 AttributeError 异常,而 Person.people.all...需要注意的是Managers 只能通过模型类访问,而不是通过模型实例,目的是强制分离 “表级” 操作和 “行级” 操作。 什么时候QuerySet被执行?...字段查找 由于字段查询非常多,也非常常用,本文不进行说明。请直接参考Django字段查询 参考资料: 执行查询 QuerySet API参考 管理器
综上所述,Django 提供了一个自动生成的数据库访问 API。 ? 在项目 manage.py 目录下,执行 python manage.py shell 进入 shell ?... Tb.objects.values(*field) 返回一个 ValueQuerySet — 一个特殊的 QuerySet,运行后得到的并不是一系列 model 的实例化对象,而是一个可迭代的字典序列... Tb.objects.values_list(*field) 它与 values() 非常相似,它返回的是一个元组序列,values 返回的是一个字典序列。 ?... Tb.objects.distinct() 从返回结果中剔除重复记录(如果查询跨越多个表,可能在计算 QuerySet 时得到重复的结果。...此时可以使用 distinct(),注意只有在 PostgreSQL 中支持按字段去重。) ? Tb.objects.count() 返回数据库中匹配查询(QuerySet)的对象数量。
filter返回的是一个QuerySet对象,filter里可以设定多个过滤条件 4、查 查询数据使用QuerySet API。...,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列 exclude(**kwargs) 包含了与所给的筛选条件不匹配的对象 order by(*field)...7. values(): values(fields, *expressions) 返回一个包含数据的字典的queryset,而不是模型实例。 ...': 'Linxiao'}]> 8.values_list(): values_list(*fields, flat=False) 与values()类似,只是在迭代时返回的是元组而不是字典...__gt=4 九、实例 1、Django的ORM中如何判断查询结果是否为空,判断django中的orm为空 result= Booking.objects.filter() 方法一 .exists()
——一个特殊的QuerySet,运行后得到的并不是一系列 model的实例化对象,而是一个可迭代的字典序列 # exclude...,values返回的是一个字典序列 # count(): 返回数据库中匹配查询(QuerySet)的对象数量。...与惰性机制 所谓惰性机制:Publisher.objects.all()或者.filter()等都只是返回了一个QuerySet(查询结果集对象),它并不会马上执行sql,而是当调用QuerySet的时候才执行...聚合查询和分组查询 aggregate(*args,**kwargs): 通过对QuerySet进行计算,返回一个聚合值的字典。...,是Book模型中price字段的平均值 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。
QuerySet API: 我们通常做查询操作的时候,都是通过模型名字.objects的方式进行操作。...他的方法全部都是通过Python动态添加的方式,从QuerySet类中拷贝过来的。 所以我们如果想要学习ORM模型的查找操作,必须首先要学会QuerySet上的一些API的使用。...默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典:...如果在values中没有传递任何参数,那么将会返回这个恶模型中所有的属性。 values_list:类似于values。只不过返回的QuerySet中,存储的不是字典,而是元组。...这个字段跟values有点类似,只不过defer返回的不是字典,而是模型。
如果没有提供Hint 实例,或者该实例当前没有数据库状态,主路由将分配default 数据库。 一个例子 只是为了示例! 这个例子的目的是演示如何使用路由这个基本结构来改变数据库的使用。...它有意忽略一些复杂的问题,目的是为了演示如何使用路由。 如果myapp中的任何一个模型包含与其它 数据库之外的模型的关联,这个例子将不能工作。...只需要在QuerySet上调用using()就可以让QuerySet使用一个指定的数据库。 using() 接收单个参数:你的查询想要运行的数据库的别名。...(create_user() 方法只能在User.objects上使用,而不能在从管理器得到的QuerySet上使用)。...(包括不是存储在同一个数据库中的模型)。
Django 提供F表达式 来允许这样的比较。 F() 返回的实例用作查询内部对模型字段的引用。 这些引用可以用于查询的filter 中来比较相同模型实例上不同字段之间值的比较。...QuerySet 方法 Django 提供了一系列 的QuerySet筛选方法,用于改变 QuerySet 返回的结果类型或者SQL查询执行的方式。...values() values(*fields, **expressions) 返回一个返回字典的QuerySet,而不是使用模型实例作为一个迭代。.....]> select_related() select_related(*fields) 返回一个QuerySet,当执行它的查询时它沿着外键关系查询关联的对象的数据。...会话对象指南 在request.session 上使用普通的Python 字符串作为字典的键。 这主要是为了方便而不是一条必须遵守的规则。
属性名 说明 queryset 视图使用的基础查询集,用于获取模型实例...lookup_field 用于查询单个对象的模型字段,默认值为 'pk'(主键)。若使用自定义字段,需确保视图和序列化器同步设置。...数据查询相关方法get_queryset(self):返回视图使用的查询集,是获取数据的主要入口。...() # 仅返回当前用户发布的文章get_object(self):返回详细视图所需的单个对象实例。...filter_queryset(self, queryset):应用过滤后端对查询集进行过滤,返回处理后的查询集。
重点内容回顾-DRF 1. on_delete on_delete是定义模型类中外键的一个选项。 on_delete选项指明的是主表删除数据的时候,对于外键引用的表数据如何处理。...5.2Restful API接口设计风格 关键点: a.url地址尽量使用名词,不要使用动词; b.请求url地址采用不同的请求方式执行不同的操作;(POST新增/GET获取/PUT修改/DELETE删除...数据库查询 属性: queryset(指定视图所使用的查询集) 方法: get_queryset返回视图所使用的查询集 get_object从视图所使用的查询集中查询指定的对象,默认根据pk进行查询。...使用场景: 根据不同的操作返回不同的序列化器类和不同的查询集,重写 get_serializer_class和 get_queryset方法。...返回latest操作使用的查询集 else: # 返回其他操作所使用的查询集 5.6.6路由Router 作用 配合视图集进行使用,动态生成视图集中处理函数的url配置项。
通常,查询集 的切片返回一个新的查询集 —— 它不会执行查询。...理解它是如何工作的将让你编写最高效的代码。叫做queryset缓存空间 在一个新创建的查询集中,缓存为空。...这是因为你不能只创建 Person和 Group之间的关联关系,你还要指定 Membership模型中所需要的所有信息;而简单的add、create 和赋值语句是做不到这一点的。...所以它们不能在使用中介模型的多对多关系中使用。此时,唯一的办法就是创建中介模型的实例。 remove()方法被禁用也是出于同样的原因。但是clear() 方法却是可用的。...select_related 返回一个QuerySet,当执行它的查询时它沿着外键关系查询关联的对象的数据。它会生成一个复杂的查询并引起性能的损耗,但是在以后使用外键关系时将不需要数据库查询。
这三个参数可以同时使用. match 仅应用于 base filename, 而不是路径全名....()获取所有的书籍,查询这里大家就掌握谁调用的下面的方法 查询API(都是重点) all(): 查询所有结果,结果是queryset类型 filter...(): queryset类型的数据来调用,返回数据库中匹配查询(QuerySet)的对象数量。...queryset类型的数据来调用,如果QuerySet包含数据,就返回True,否则返回False 空的queryset类型数据也有布尔值True和False,但是一般不用它来判断数据库里面是不是有数据...model的实例化对象,而是一个可迭代的字典序列,只要是返回的queryset类型,就可以继续链式调用queryset类型的其他的查找方法,其他方法也是一样的。
在更高层的与处理Django 模型实例相关的代码中:使用get_absolute_url() 方法。...6位数字,2表示必须有两位小数,1111.22这样的形式 一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行关于表记录的增删改查的操作 技巧 通过logging可以查看翻译成的...API 查询记录API(QuerySet) 从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet all(): 查询所有结果 Returns a new...返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列 ret = Book.objects.all().values...,第二这个api返回的是什么 QuerySet 支持链式查询 找出名称含有abc, 但是排除年龄是23岁的 Person.objects.filter(name__contains="abc").exclude
QuerySet API 我们通常做查询操作的时候,都是通过模型名字.objects的方式进行操作。...其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...他的方法全部都是通过Python动态添加的方式,从QuerySet类中拷贝过来的 ? image 所以我们如果想要学习ORM模型的查找操作,首先要学会QuerySet上的一些API的使用。 2....默认情况下会把表中所有的字段全部都提取出来,可以使用values来进行指定,并且使用了values方法后,提取出的QuerySet中的数据类型不是模型,而是在values方法中指定的字段和值形成的字典...只不过返回的QuerySet中,存储的不是字典,而是元组 articles = Article.objects.values_list("id","title") print(articles) 那么在打印
(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列 values_list...() 特殊的QuerySet values() 返回一个可迭代的字典序列 values_list() 返回一个可迭代的元祖序列 返回具体对象的 get() first() last() 返回布尔值的方法有...聚合查询和分组查询 聚合 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。...如果你需要执行更复杂的查询(例如OR语句),你可以使用Q对象。...同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询。 示例:查询作者名字是小仙女并且不是2018年出版的书的书名。
,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列 values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列...() 特殊的QuerySet values() 返回一个可迭代的字典序列 values_list() 返回一个可迭代的元祖序列 返回具体对象的 get() first() last() 返回布尔值的方法有...换句话说,在关联的任何一端,都不需要再调用save()方法。 聚合查询和分组查询 聚合 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。...如果你需要执行更复杂的查询(例如OR语句),你可以使用Q对象。...同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询。 示例:查询作者名字是小仙女并且不是2018年出版的书的书名。