gpt4 book ai didi

django - South 没有及时为新模型创建默认权限,以便后续迁移使用它们

转载 作者:行者123 更新时间:2023-12-01 19:26:57 25 4
gpt4 key购买 nike

我不是 100% 确定我这样做是正确的,但我认为我发现了一个问题,即 auth.Permission 对象没有足够快地创建以供迁移使用它们当您从头开始初始化数据库时。

重要细节:

  • 我正在尝试使用 ./manage.pysyncdb --migrate --noinput 从头开始​​初始化 Django 数据库

  • 我的链中有 11 个迁移

  • 第一次迁移创建了一个名为 myapp.CompanyAccount

  • 的新模型
  • 第 9 次迁移尝试通过以下方式获取权限 myapp.change_companyaccount:

p = orm[ "auth.Permission"].objects.get( codename = "change_companyaccount")

此时,会引发异常:

django.contrib.auth.models.DoesNotExist:权限匹配查询不存在

我曾假设为每个对象定义的默认权限(根据 http://docs.djangoproject.com/en/dev/topics/auth/#default-permissions )将在第一次迁移完成时创建,但似乎并非如此。如果我在异常后重新运行迁移,它会第二次工作,因为显然权限现在存在,并且第九次迁移可以执行而不会出错。

在第九次迁移运行之前,是否可以采取任何措施来“刷新”所有内容,以便整个过程可以一次性运行而无需退出?

感谢您的帮助/建议。

编辑:为了回应下面约翰的评论,我发现以下命令行序列可以工作:

  1. ./manage.pysyncdb(这会初始化默认的 Django 表)
  2. ./manage.py migrate myapp 0001(这会导致创建 CompanyAccount 表)
  3. ./manage.py migrate myapp(这会一直迁移到最后,不会出现错误)

不幸的是,跳过上面的步骤 #2 意味着您在 0009 迁移中会遇到相同的异常,这告诉我,我最初的怀疑是正确的,新模型的默认权限不是立即由 South 创建的,而是以某种方式仅推送到当整个迁移链完成时数据库。

这比我以前的情况要好(我现在至少避免了异常),但我仍然需要围绕创建新模型手动分段迁移,后续迁移可能需要触及其权限,所以这不是'一个完整的解决方案。

最佳答案

事实证明,答案是在尝试访问默认权限之前的某个时刻手动调用db.send_pending_create_signals(),因为 South 只在很晚的时候才执行此“刷新”步骤过程。感谢来自南方的安德鲁·戈德温 (Andrew Godwin) 在此处的南方邮件列表上回复此问题:

http://groups.google.com/group/south-users/browse_thread/thread/1de2219fe4f35959

关于django - South 没有及时为新模型创建默认权限,以便后续迁移使用它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6023508/

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