python – Django:获取查询集的补充
发布时间:2020-12-16 23:40:14 所属栏目:Python 来源:网络整理
导读:我得到一个特定模型的查询集,我想得到它的补充,即该模型的所有实例都不在上述查询集中. 我怎样才能做到这一点? 解决方法 简短解决方案 qs = Model.objects.filter(...) # qs with objects to excluderesult = Model.objects.exclude(pk__in=qs.values_list(
我得到一个特定模型的查询集,我想得到它的补充,即该模型的所有实例都不在上述查询集中.
我怎样才能做到这一点? 解决方法
简短解决方案
qs = Model.objects.filter(...) # qs with objects to exclude result = Model.objects.exclude(pk__in=qs.values_list('pk',flat=True)) 更多DRY解决方案 但是,如果您想多次使用逻辑,我建议将其封装在一个方法中.这是我在自定义查询集中使用的一个例子: class QuerysetUtils: def get_queryset_complement(self,method): return self.exclude(pk__in=method().values_list('pk',flat=True)) class ExpirableQueryset(QuerysetUtils,models.query.QuerySet): def expired(self): return self.filter(expiration__lte=timezone.now()) def unexpired(self): return self.get_queryset_complement(self.expired) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |