Python Django,数据库,QuerySet查询集(类似列表)

 

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。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值