4

post_syncdb我正在尝试使用信号在创建表后立即向数据库添加一些数据。

signals.post_syncdb.connect(init)

然后在init函数中,我要设置权限,所以我用

ct = ContentType.objects.get(app_label='news', model='Article')
Permission(name='Approve articles', codename='can_approve_article', content_type=ct)

但是,如果我放下所有桌子并运行syncdb,我会得到

...
File "...\base\functions\init.py", line 11, in init
  ct = ContentType.objects.get(app_label='news', model='Article')
...
django.contrib.contenttypes.models.DoesNotExist: ContentType matching query does not exist.

我做过的一些测试:

  • 如果我在外面尝试这段代码,它工作正常syncdb
  • 如果我让syncdb创建没有此代码的所有表,然后添加此代码并运行 syncdb 而无需进行任何更改,它也可以正常工作。
  • 而且我很确定它曾经可以工作,但是从那以后我在其他地方改变了很多东西,所以我不知道从哪里开始。
  • 对于不同应用程序中的其他模型,我得到相同的错误。
  • 信号被触发大约 10 次,只有前几次抛出错误。

非常感谢任何提示!

4

1 回答 1

7

将此添加到 init 函数的开头:

 from django.contrib.contenttypes.management import update_all_contenttypes
 update_all_contenttypes() # make sure all content types exist
于 2013-07-12T12:15:28.950 回答