Django .only()导致最大递归深度超出错误?

时间:2017-08-07 13:12:56

标签: python django recursion django-models django-orm

我正在使用Django的.only()构造来仅查询我需要的列。

离。

Trainer.objects.filter(id__in=ids).only('id', 'lives')

这是我写的一个快速例子来重现这个:

class BaseTrainer(models.Model):

    mode = models.IntegerField(help_text="An integer")

    def __init__(self, *args, **kwargs):
    super(BaseTrainer, self).__init__(*args, **kwargs)
    self._prev_mode = self.mode


class Trainer(BaseTrainer):

    name = models.CharField(max_length=100, help_text="Name of the pokemon")
    trainer_id = models.CharField(max_length=10, help_text="trainer id")
    badges = models.IntegerField(help_text="Power of the pokemon (HP)")
    lives = models.PositiveIntegerField(default=sys.maxsize)

    unique_together = ("name", "trainer_id")

    def __init__(self, *args, **kwargs):
        super(Trainer, self).__init__(*args, **kwargs)
        self._temp = self.lives

    @classmethod
    def test(cls):

        t = Trainer.objects.only('trainer_id').all()

        print(t)

我只需要id和name字段,这是肯定的。 maximum recursion depth exceeded的原因是什么?

1 个答案:

答案 0 :(得分:3)

事实证明maximum recursion depth exceeded的原因是因为从模型和构造函数重写继承。

正如您在代码中看到的那样,

self._prev_mode = self.mode

我们尝试在超类模型的构造函数中访问mode。 因此,即使我们不需要此字段供我们使用,我们仍然必须在.only()中将此包含在此模型的每个此类调用中。

但是,根据文档,.only()应该进行另一个数据库查询以获取最坏情况下的字段值,为什么递归?

请注意,此字段是在父模型的构造函数中访问的。这就是问题所在。每次都无法在构造函数中读取该值,因此尝试从数据库中获取该值。 这再次调用了构造函数,递归周期一直持续到python停止它为止。

无论如何,通过在mode电话中添加.only()来解决此问题。

Trainer.objects.filter(id__in=ids).only('id', 'name', 'mode')