加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读