Django
常用操作
Django生产设置
Setting设置
装饰器
类
类--验证登陆
ListView
CreateView
DeleteView
URL方法
Views方法
model数据模型
models
admin
views
url
model查询操作
model聚合查询
model列操作及复杂查询
登录退出
登陆成功后跳转指定页面
修改密码
重置密码
分页
标签
HTML文件
开启HTTPS
CSRF
本文档使用MrDoc发布
返回首页
-
+
model列操作及复杂查询
2020年11月11日 11:49
admin
##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) ##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='老王')
分享到: