D5

F对象 用于属性和属性之间的比较

F对象
1 可以使用模型的A属性与B属性进行比较
from django.db.models import F,Q
def grades(request):
g = Grades.objects.filter(ggirlnum_gt=F(‘gboynum’)) 找到女生人输大于男生人数的班级

g = Grades.objects.filter(ggirlnum_gt=F(‘gboynum’),ggirlnum) 后面加逗号表示and

2 支持F对象的算术运算 filter(ggirlnum_gt=F(‘gboynum’)+20)
3 F对象的参数可以是跨表字段
models.Book.objects.filter(bread_num=F(’‘author_name’))
4 F对象参数如果是date/time,可以进行日期的加减运算:
models.Book.objects.filter(bpub_date__lt=F(‘bpub_date’) + timedelta(days=5))

Q对象
概述 过滤器的方法中的关键字参数,条件为And模式,采用逻辑或引入Q对象
需求 进行or查询,或查询
解决 使用Q对象

Q对象可以使用&(and)、|(or)操作符组合起来
studentList = Student.objects.filter(Q(pklt = 3)|Q(sagegt=50)) pk_id小于3或年龄大于50岁
models.User.objects.filter(Q(username=‘老王’) & Q(userpass=‘admin’)) 条件与组合
models.User.objects.filter(~Q(username=‘老王’)) 条件非表示取反
可以使用 &(and) |(or) ~(not) 结合括号进行分组,构造更复杂的Q对象
filter函数可以传递一个或多个Q对象作为位置参数,如果有多个Q对象,这些参数的逻辑为and

下面分享一个综合用法:

def get(self, request, *args, **kwargs):
filters = request.GET
#找出符合customer的数据转成列表
Qs = [Q(customer=request.user.customer)]
try:
if ‘limit’ in filters:
limit = abs(int(filters[‘limit’]))
if limit > 50:
limit = 50
else:
limit = 15
start_id = int(filters.get(‘start_id’, 0))
#添加符合start_id的对象
Qs.append(Q(idgt=start_id))
#添加符合状态的state
if ‘state’ in filters:
Qs.append(Q(statein=filters[‘state’]))
else:
Qs.append(Q(statein=[0, 1, 2, 3, 4]))
#添加符合title的数据
if ‘title’ in filters:
Qs.append(Q(titlecontains=filters[‘title’]))
except Exception:
return params_error({“filters”: “过滤参数不合法”})

    #通过*Qs,对列表数据同时满足上述情况的数据进行总的帅选,并设置限制集
    sets = Questionnaire.objects.filter(*Qs)[:limit]

F对象用来比较两个属性之间的对比,

Q对象用来表示各个关系

常见的聚合函数:
使用aggregate()函数返回聚合函数的值
Avg Count Max Min sum
from dango.db.models import Max
maxAge = Student.objects.aggregate(Max(‘sage’)) 找出学生年龄最大的
F对象
1 可以使用模型的A属性与B属性进行比较
from django.db.models import F,Q
def grades(request):
g = Grades.objects.filter(ggirlnum_gt=F(‘gboynum’)) 找到女生人输大于男生人数的班级
2 支持F对象的算术运算 filter(ggirlnum_gt=F(‘gboynum’)+20)
3 F对象的参数可以是跨表字段
models.Book.objects.filter(bread_num=F(’‘author_name’))
4 F对象参数如果是date/time,可以进行日期的加减运算:
models.Book.objects.filter(bpub_date__lt=F(‘bpub_date’) + timedelta(days=5))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值