Django 多对多:获取一个相关查询集中的元素但排除其他相关查询集中的元素的最佳方法?

Django many-to-many: Best way to get elements in one related query set but exclude elements in other related query sets?

考虑这些相关模型:

class A(models.Model):
    name = models.CharField(max_length=250, unique=True)
    bs = models.ManyToManyField(B)

class B(models.Model):
    pass

在视图中,我需要查询以获取与给定 A 相关的所有 B,同时排除所有 Bs 与一组其他 As 相关。我需要灰色区域:

我目前的效率极低的方法如下:

bs_for_a1 = A.objects.get(name=a1).bs.all()

for previous_A in previous_As:
    previous_bs = A.objects.get(name=previous_A).bs.all()
    bs_for_a1 = bs_for_a1.difference(previous_bs)

在我的应用程序中,previous_As 可能有将近 1,000 个元素,这使得这种方法非常昂贵。有一个更好的方法吗?我可以完全控制 models/schema 的检修。我希望任何给定的查询,包括选择相关模型和相关排序,都能在 1 秒内完成。

我认为更好的方法可能涉及直接在转换 table 上进行原始 SQL 查询。我正在使用带有 sqlite 的 Django 3.0。生产将使用 Postgres。

看来我把这件事变得比必要的更难了。这似乎适用于给定的插图:

previous_As = (a2.name, a3.name, a4.name)
b1_minus_previous = B.objects.exclude(a__name__in=previous_As).filter(a__name=a1)