Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/281.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Django查询-基于查询数据的预取过滤器?_Python_Django - Fatal编程技术网

Python Django查询-基于查询数据的预取过滤器?

Python Django查询-基于查询数据的预取过滤器?,python,django,Python,Django,我正在尝试根据父查询对象筛选预回迁,这可能吗?希望下面的例子能够解释 SiteData中的活动链接类型和回路中的回路类型使用相同的子模型 因此,例如,如果活动链接类型为“光纤”,我只想预取具有“光纤”电路类型的电路。每个站点可以有许多电路,但我现在只想要一个带电的 以下是查询: conn_stats = SiteData.objects.all() .exclude(site_type__site_type='Factory') \ .exclude(site_type__sit

我正在尝试根据父查询对象筛选预回迁,这可能吗?希望下面的例子能够解释

SiteData中的活动链接类型和回路中的回路类型使用相同的子模型

因此,例如,如果活动链接类型为“光纤”,我只想预取具有“光纤”电路类型的电路。每个站点可以有许多电路,但我现在只想要一个带电的

以下是查询:

conn_stats = SiteData.objects.all()
    .exclude(site_type__site_type='Factory') \
    .exclude(site_type__site_type='Data Centre') \
    .Prefetch(
        'circuits_set',
        queryset=Circuits.objects.filter(SiteData.objects.live_link_type.circuit_type)
        )
)
这些是模型:

class CircuitTypes(models.Model):
    circuit_type = models.CharField(max_length=50)
    monitor_priority = models.IntegerField(verbose_name="Monitoring Priority", blank=True, null=True)
    class Meta:
        verbose_name = "Circuit Types"
        verbose_name_plural = "Circuit Types"
    def __str__(self):
        return self.circuit_type

class SiteData(models.Model):
    location = models.CharField(max_length=50)
    site_type = models.ForeignKey(SiteTypes, verbose_name="Site Type", \
                on_delete=models.PROTECT)
    is_live = models.BooleanField(default=False, verbose_name="Is this a live site?")
    live_link_type = models.ForeignKey(CircuitTypes, verbose_name="Link Type", \
                on_delete=models.PROTECT, default=1)
    live_link_preference = models.CharField(max_length=200, blank=True, null=True)
    live_link_query_timestamp = models.DateTimeField(auto_now_add=True, blank=True, null=True)

class Circuits(models.Model):
    site_data = models.ForeignKey(SiteData, verbose_name="Site", on_delete=models.PROTECT)
    order_no = models.CharField(max_length=200, verbose_name="Order No")
    expected_install_date = models.DateField()
    install_date = models.DateField(blank=True, null=True)
    circuit_type = models.ForeignKey(CircuitTypes, verbose_name="Circuit Type", on_delete=models.PROTECT)
    ...

据我所知,你不能用一个查询集来完成你的要求

如果电路类型的数量较小,可以考虑为每种类型的电路构造一个QuestSub:

circuit_types = CircuitType.object.all()
for circuit_type in circuit_types:
    prefetch = Prefetch('circuits_set',
                        queryset=Circuits.objects.filter(
                            circuit_type=circuit_type)
    conn_stats = SiteData.objects.filter(live_link_type=circuit_type) \
        .exclude(site_type__site_type='Factory') \
        .exclude(site_type__site_type='Data Centre') \
        .prefetch_related(prefetch)
如果有许多回路类型,并且这是禁止的,则您可以向回路添加布尔活动字段,并在更改每个SiteData.live\u link\u类型时更新其值。这样,您将只能直接查询活动回路:

prefetch = Prefetch('circuits_set',
                    queryset=Circuits.objects.filter(active=True)
conn_stats = SiteData.objects.all() \
    .exclude(site_type__site_type='Factory') \
    .exclude(site_type__site_type='Data Centre') \
    .prefetch_related(prefetch)

谢谢,我相信你是对的,我将把活动字段从站点数据模型移到电路模型,这将解决问题