all, filter, exclude, order_by调用这些函数会产生一个QuerySet查询集。
QuerySet查询集类似列表,可以遍历、切片,有下标(下标不能为负数)。
查询集的特性:
1、惰性查询(懒加载):只有在实际使用查询集中的数据的时候才会发生对数据库的真正查询。
2、缓存:当使用的是同一个查询集时,第一次的时候会发生实际数据库的查询,然后把结果缓存起来,之后再使用这个查询集时,使用的是缓存中的结果。
限制查询集(切片)
可以对一个查询集进行取下标或者切片操作来限制查询集的结果(等同于sql中的limit和offset子句)。
对一个查询集进行切片操作会产生一个新的查询集,下标不允许为负数。
取出查询集第一条数据的两种方式:
b[0] # 如果b[0]不存在,会抛出IndexError异常。
b[0:1].get() # 如果b[0:1].get()不存在,会抛出DoesNotExist异常。
exists():判断查询集中是否有数据,如果有则返回True,没有则返回False。