gpt4 book ai didi

mysql - 为什么升级我的版本 django-mptt 后出现此数据库迁移错误?

转载 作者:IT老高 更新时间:2023-10-29 00:08:34 35 4
gpt4 key购买 nike

我的 Django 应用程序有一个 requirements.txt 文件(显示为 here ),我用它在我的虚拟环境中安装模块。一切正常。

但是,我现在正在尝试将 django-mptt 从 0.6.1 升级到最新版本。 (我实际上并不关心升级 django-mptt。我只是想升级我的 Django 版本。但似乎要升级 Django,我必须先升级 django-mptt,如 here 所述)。所以我执行 pip install -U django-mptt。这导致 django-mptt 从 0.6.1 到 0.7.4,Django 从 1.7.1 到 1.8.2。它还会导致 django-cache-machine 从源到主。您可以在下面的屏幕截图中看到更改。

然后,当我执行 manage.py runserver 时,它会提示我进行迁移。所以我这样做了。没问题。但是随后如果我删除所有表然后再次运行迁移,我在迁移过程中会收到此错误:

django.db.utils.OperationalError: 
(1005, 'Can\'t create table `mydb_instance`.`#sql-21b_1e`
(errno: 150 "Foreign key constraint is incorrectly formed")')

完整的堆栈跟踪是 here .

这是什么错误?这是否与我使用 MariaDB(服务器版本:10.0.15-MariaDB Homebrew)而不是 MySQL 作为我的数据库有关?

enter image description here

编辑:此点以下的部分已于 2015 年 7 月 6 日 5:28 UTC 添加

我上面提到升级后,系统提示我进行迁移。奇怪的是,即使升级 MPTT 不会导致创建任何新的迁移文件,也会发生这种情况!当我执行 manage.py runserver 时,我收到以下警告消息。为什么?这毫无意义:

You have unapplied migrations; your app may not work properly until they are applied.
Run 'python manage.py migrate' to apply them.

编辑:此点以下的部分已于 2015 年 7 月 6 日 17:00 UTC 添加

作为实验,我将底层数据库从 MariaDB 切换到 MySQL(服务器版本:5.6.25)。问题仍然存在。我得到的错误是 Cannot add foreign key constraint。完整的堆栈跟踪是 here .

编辑:此点以下的部分已于 2015 年 7 月 6 日 17:05 UTC 添加

查看我 5 分钟前发布的堆栈跟踪,我发现错误是由以下 SQL 语句触发的:

ALTER TABLE `myapp2_mymodel2` ADD CONSTRAINT `mymod_mymodel5_id_335ee73cecd6ecbf_fk_myapp5_mymodel5_id` FOREIGN KEY (`mymodel5_id`) REFERENCES `myapp5_mymodel5`;

我明白是什么问题了。 myapp2_mymodelmyapp5_mymodel 有一个外键约束。然而,当它试图创建这个 FK 时,它失败了,因为外键的目标还不存在!为什么升级后建表顺序不一样?

最佳答案

我自己解决了这个问题。看起来我的 Django 应用程序之一缺少 myapp2 缺少迁移文件夹。我修复了它,一切开始正常运行。

关于mysql - 为什么升级我的版本 django-mptt 后出现此数据库迁移错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31177651/

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