我有 2 个模型, Bacon
和Eggs
两者都ForeignKey
Spam
模型。
我需要找出与Eggs
无关的培根,目前我通过以下方式
objs = Bacon.objects.select_related.filter(somefilter=value)
for obj in objs:
if obj.spam.eggsspam.count():
continue
do_something()
我相信一定有更优化的方法吗?
尝试:
Bacon.objects.filter([m2m_field_name]__isnull=True)
你想要注释。代码将如下所示:
Bacon.objects.annotate(num_eggs=Count('spam__egg_set')).filter(num_eggs__eq=0)