Django 中 Models 的 F()和 Q()函数

  1. F() ---- 专门取对象中某列值的操作
    F对象允许Django在未实际链接数据的情况下具有对数据库字段的值的引用。
    通常情况下我们在更新数据时需要先从数据库里将原数据取出后方在内存里,然后编辑某些属性,最后提交。
all = BookInfo.objects.filter(auth="小明")
for b in all:
    price = b.price
    b.price = price + 10
    b.save
    
# 使用F对象来计算
BookInfo.objects.filter(auth="小明").update(price=F("price")+10)
  1. Q() ---- 对对象的复杂查询
    Q对象是Django对model查询中所使用的关键字参数进行封装后的一个对象。
    Q对象可以通过 &(与)、 |(或)、 ~(非)运算来组合生成不同的Q对象,便于在查询操作中灵活地运用。
from django.db.models import Q
# 并且条件:与条件查询
models.User.objects.filter(条件1,条件2,条件n..)
models.User.objects.filter(Q(username='老王') & Q(userpass='admin'))

# 或者条件:或条件
models.User.objects.fliter(Q(username='老王') | Q(username='老李'))

# 取反条件
models.User.objects.filter(~Q(username='老王'))
models.User.objects.exclude(username='老王')

你可能感兴趣的:(Python,Django)