我正在嘗試構建自定義模型管理器,但遇到了錯誤。代碼如下所示:Django自定義模型管理器數據庫錯誤
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()
(我曾與get_options
發揮各地比較使用super()
等方式來過濾結果很多)
當我運行syncdb
,我得到以下錯誤(ops_lookup
感相應的表):
django.db.utils.DatabaseError: no such table: ops_lookup
我注意到,如果我改變了經理返回[]
,而不是一個過濾器,然後syncdb
作品。另外,如果我運行了syncdb
並且所有表都存在,那麼將代碼更改爲上面的代碼,它也可以工作。
我該如何讓Django第一次運行syncdb
時不要期望這張表存在?
更新 通過回溯追溯之後,我意識到發生了什麼事。查找表旨在包含填充其他表中某些列的選項的值。我認爲會發生什麼情況是,當創建其他表時,管理器會被調用,看起來,在創建查找表之前會發生這種情況。
有沒有辦法強迫Django的先創建查找表(短重命名呢?)
請使用--traceback運行syncdb,併發布完整的回溯。 – jpic