首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Django之QuerySet详解

一、QuerySet何时被提交 在内部,创建、过滤、切片和传递一个QuerySet不会真实操作数据库,在你对查询集提交之前,不会发生任何实际的数据库操作。...可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...二、QuerySet class QuerySet(model=None, query=None, using=None)[source] QuerySet类具有两个公有属性用于内省: ordered...(pk=entry.pk).exists(): print("Entry contained in queryset") 它将比下面的方法快很多,这个方法要求对QuerySet求值并迭代整个QuerySet...: if entry in some_queryset: print("Entry contained in QuerySet") 若要查找一个QuerySet是否包含任何元素: if some_queryset.exists

2.2K20

Django中的QuerySet

一、QuerySet   查询集,类似一个列表,包含了满足查询条件的所有项。QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作。只有你查询的时候才真正的操作数据库。...意味着QuerySet是惰性执行的----即创建查询集不会带来任何的数据库访问,直到查询集需要求值的时候,Django才会真正运行这个查询。... exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。... count(): 返回数据库中匹配查询(QuerySet)的对象数量。

1.3K32

Django学习笔记:QuerySet API

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

59620

Django的Manager和QuerySet

Django的Manager和QuerySet 要从数据库检索对象,需要通过模型类的 Manager 构建一个 QuerySet。...QuerySet 一个 QuerySet 代表来自数据库中对象的一个集合。它可以有 0 个,1 个或者多个 filters。 可以根据给定参数缩小查询结果量。...什么时候QuerySet被执行? 在Django的文档中,明确的告诉了开发者,什么时候QuerySet被执行。因为这影响到SQL执行效率。...QuerySet 类具有两个可用于自省的公开属性: 可以返回QuerySet对象的QuerySet方法 前文所述的看起来做了3次SQL查询,实际上只有一次。...下面介绍一下常用的可以返回QuerySet对象的QuerySet方法 不能返回QuerySet对象的QuerySet方法 下面介绍一些常用的不能返回QuerySet对象的QuerySet方法。

1.1K30

Django学习笔记之Queryset详解

Queryset简介 每个Model都有一个默认的manager实例,名为objects,QuerySet有两种来源:通过manager的方法得到、通过QuerySet的方法得到。...一个QuerySet包含一个或多个model instance。QuerySet类似于Python中的list,list的一些方法QuerySet也有,比如切片,遍历。...’> QuerySet是延迟获取的,只有当用到这个QuerySet时,才会查询数据库求值。...1.5 len() 计算QuerySet元素的数量,并不推荐使用len(),除非QuerySet是求过值的(即evaluated),否则,用QuerySet.count()获取元素数量,这个效率要高。...WHERE pub_date IS NULL; 2.4.18  QuerySet切片——对应于limit     QuerySet的索引只能是非负整数,不支持负整数,所以QuerySet[-1]错误 a

2.7K30

Django QuerySet查询集原理及代码实例

情况一:重复获取查询集对象中一个特定的索引将每次都查询数据库: queryset = BookInfo.objects.all() queryset[5] # 查询数据库 queryset[5]...in queryset] # 查询数据库 print queryset[5] # 使用缓存 print queryset[5] # 使用缓存    情况三:下面是一些其它例子,它们会使得全部的查询集被求值并填充到缓存中...: # 获取查询集 queryset = BookInfo.objects.all() [entry for entry in queryset] bool(queryset) entry in queryset...list(queryset)   注:简单地打印查询集不会填充缓存。  ...当queryset非常巨大时,cache会成为问题。   处理成千上万的记录时,将它们一次装入内存是很浪费的。更糟糕的是,巨大的queryset可能会锁住系统 进程,让你的程序濒临崩溃。

1.3K21

【实测】django的QuerySet 应该怎么用?

所以,queryset 是什么?是查询结果的集合的意思。 我就不用那些标准的百度百科的回答了,咱直接上代码,从数据直接拿出来的数据来当例子,你就明白了。...好然后我们用一段函数来把数据从中取出来并打印: 结果如下: 可以看到,直接从数据库用.all 或者.filter方法拿出来的 结果是queryset,也就是查询集合。...所以queryset的另一个特性就是可以像列表一样遍历和用下标定位具体内部元素: 遍历的具体子元素,都是一个个货真价实的数据记录哈。 别看我直接输出,就显示一个link_name的值。...此时我们得到的仍然是queryset,但结果中,却显示了所有字段。 这样我们用起来就更方便。为什么这么说呢? 因为我们可以把它外面再加上list() 变成我们python常用的格式了。

54510
领券