gpt4 book ai didi

Django自定义模型管理器数据库错误

转载 作者:行者123 更新时间:2023-12-03 04:34:06 24 4
gpt4 key购买 nike

我正在尝试构建自定义模型管理器,但遇到了错误。代码如下所示:

class LookupManager(models.Manager):
def get_options(self, *args, **kwargs):
return [(t.key, t.value) \
for t in Lookup.objects.filter(group=args[0].upper())]


class Lookup(models.Model):
group = models.CharField(max_length=1)
key = models.CharField(max_length=1)
value = models.CharField(max_length=128)
objects = LookupManager()

(我使用 super() 和其他方法来过滤结果,经常使用 get_options)

当我运行 syncdb 时,出现以下错误(ops_lookup 是相应的表):

django.db.utils.DatabaseError: no such table: ops_lookup

我注意到,如果我将管理器更改为返回 [] 而不是过滤器,则 syncdb 可以工作。另外,如果我运行了 syncdb 并且所有表都存在,那么将代码更改为上面的代码,它也可以工作。

如何让 Django 在第一次运行 syncdb 时不希望该表存在?

更新查看回溯后,我意识到发生了什么。查找表旨在包含填充其他表中某些列的选择的值。我认为发生的情况是,当创建其他表时,管理器被调用,这似乎发生在创建查找表之前。

有没有办法强制 django 首先创建查找表(不重命名它?)

最佳答案

发生的情况是您尝试在模块加载期间访问数据库。例如:

class MyModel(models.Model):
name = models.CharField(max_length=255)


class OtherModel(models.Model):
some_field = models.CharField(
max_length=255,
# Next line fails on syncdb because the database table hasn't been created yet
# but the model is being queried during module load time (during class definition)
choices=[(o.pk, o.name) for o in MyModel.objects.all()]
)

这相当于您正在做的事情,因为正如您所说,您正在使用管理器方法(传递性地)为其他模型生成选择。

用生成器表达式替换列表推导式将返回一个可迭代对象,但在第一次迭代之前不会评估过滤后的查询集。因此,这将修复上面的示例:

choices=((o.pk, o.name) for o in MyModel.objects.all())

使用您的示例,它将是:

class LookupManager(models.Manager):
def get_options(self, *args, **kwargs):
return ((t.key, t.value) for t in Lookup.objects.filter(group=args[0].upper()))

(注意使用 () 而不是 [])(外部的) - 这是创建生成器表达式的语法。

关于Django自定义模型管理器数据库错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10595372/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com