- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
长话短说,Django 迁移和用户模型发生了一些我不理解的事情。关于与客户用户身份验证模型和迁移的外键关系的一些问题很无聊。
我使用 SQLite 和自定义用户对象在本地开发了应用程序:class Client(AbstractBaseUser, PermissionsMixin)
在我的 settings.py 中,我有:
AUTH_USER_MODEL = "offerdrive.Client"
一切都与 SQLite 和本地/开发一起工作,此时该应用程序具有合理的功能集。
当进入生产环境时,我尝试了 Postgres,但失败了。然后我在 RDS 上尝试了 MySQL,它以同样的方式失败了。这是 ./manage.py migrate
之后的 MySql 错误:
django.db.utils.IntegrityError: (1215, '无法添加外键约束')
这是一些好奇的 InnoDB 调试信息(来自 mysql> show engine innodb status\G
)-
------------------------
LATEST FOREIGN KEY ERROR
------------------------
2015-08-05 22:01:36 2af53b3cf700 Error in foreign key constraint of table test_drivedb/#sql-a69_248:
FOREIGN KEY (`user_id`) REFERENCES `offerdrive_client` (`id`):
Cannot resolve table name close to:
(`id`)
我以“老式”方式“扁平化”了所有迁移以确保 - rm -rf'ed
migrations
目录,并重做 进行迁移
。
一些我已经阅读和尝试过的东西未能完全解决问题:
[1] Django 1.8 RC1: ProgrammingError when creating database tables .
[2] https://code.djangoproject.com/ticket/24524
不幸的是,测试仍然以同样的方式失败——即使正常/prod 数据库被正确迁移,并且迁移工作一致,测试数据库也会因相同的外键问题而失败。
如果我注意迁移的顺序,我可以让实际的数据库正常工作:
./manage.py reset_db
./manage.py migrate auth
./manage.py offerdrive
./manage migrate
但是,这似乎不适用于测试 - 似乎运行 ./manage.py test offerdrive
不会以任何方式强制执行该命令。它以同样的方式失败 - 提示相同的外键关系。
对于像 Django 这样的框架来说,这似乎是一个绝对愚蠢的问题,我认为我正在做一些非常愚蠢的事情。该应用程序本身不会做任何奇怪或疯狂的事情。我仍然感到困惑,为什么它在 SQLite 上运行良好,但在 Postgres 或 MySQL 上运行不佳。我最好的猜测是 SQLite 在某种程度上对外键约束不那么严格,即使表是乱序创建的,它们最终也会自行解决。那个,或者别的什么。可能吧。
tl;dr 计算机很难
有什么想法吗?
更新 - 显然连续两次运行 migrate
将适用于“真实”数据库 - 但这对失败的测试没有帮助。
最佳答案
嘿,小伙子。因此,经过一些努力、与其他人的一些通信以及一点运气,最好的解决方案原来很简单——我需要 pip install --upgrade django-registration-redux
。
1) 转折点是(我不敢相信我没有早点想到这一点)在 ./manage.py migrate -v3
上启用额外的详细信息并查看它的确切位置失败(之前,我尝试通过实际的 django 迁移加载/执行代码删除调试器,结果是错误的抽象级别来查看它)
2) 查看详细的迁移输出,很明显 registration_profile
表周围发生了爆炸。 (这是迁移失败之前运行的最后一件事)。
3) 我在应用程序对应的包 (django-registration/django-registration-redux) 周围挖掘......aaaand,看起来没有迁移。这是一个问题,因为 请注意,但是,由于没有迁移的本质,未迁移的应用程序不能依赖于已迁移的应用程序。
根据“”https://docs.djangoproject.com/en/1.8/topics/migrations/#dependencies
4) 一时兴起,在尝试将我自己的迁移添加到模块之前,我用 pip 升级了
django-registration-redux
和 django-registration
安装--升级
Aaa,它修复了它。万岁#engineering!
我想指出这与自定义用户模块无关,只是一个我什至不知道的过时依赖项正在进入画面。
关于mysql - Django 1.8 迁移、自定义用户模型和 Postgres/MySQL 的奇怪问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31844053/
关闭。这个问题是off-topic .它目前不接受答案。 想要改进这个问题? Update the question所以它是on-topic用于堆栈溢出。 关闭 12 年前。 Improve thi
我有一个动态网格,其中的数据功能需要正常工作,这样我才能逐步复制网格中的数据。假设在第 5 行中,我输入 10,则从第 6 行开始的后续行应从 11 开始读取,依此类推。 如果我转到空白的第一行并输入
我有一个关于我的按钮消失的问题 我已经把一个图像作为我的按钮 用这个函数动画 function example_animate(px) { $('#cont
我有一个具有 Facebook 连接和经典用户名/密码登录的网站。目前,如果用户单击 facebook_connect 按钮,系统即可运行。但是,我想将现有帐户链接到 facebook,因为用户可以选
我有一个正在为 iOS 开发的应用程序,该应用程序执行以下操作 加载和设置注释并启动核心定位和缩放到位置。 map 上有很多注释,从数据加载不会花很长时间,但将它们实际渲染到 map 上需要一段时间。
我被推荐使用 Heroku for Ruby on Rails 托管,到目前为止,我认为我真的会喜欢它。只是想知道是否有人可以帮助我找出问题所在。 我按照那里的说明在该网站上创建应用程序,创建并提交
我看过很多关于 SSL 错误的帖子和信息,我自己也偶然发现了一个。 我正在尝试使用 GlobalSign CA BE 证书通过 Android WebView 访问网页,但出现了不可信错误。 对于大多
我想开始使用 OpenGL 3+ 和 4,但我在使用 Glew 时遇到了问题。我试图将 glew32.lib 包含在附加依赖项中,并且我已将库和 .dll 移动到主文件夹中,因此不应该有任何路径问题。
我已经盯着这两个下载页面的源代码看了一段时间,但我似乎找不到问题。 我有两个下载页面,一个 javascript 可以工作,一个没有。 工作:http://justupload.it/v/lfd7不是
我一直在使用 jQuery,只是尝试在单击链接时替换文本字段以及隐藏/显示内容项。它似乎在 IE 中工作得很好,但我似乎无法让它在 FF 中工作。 我的 jQuery: $(function() {
我正在尝试为 NDK 编译套接字库,但出现以下两个错误: error: 'close' was not declared in this scope 和 error: 'min' is not a m
我正在使用 Selenium 浏览器自动化框架测试网站。在测试过程中,我切换到特定的框架,我们将其称为“frame_1”。后来,我在 Select 类中使用了 deselectAll() 方法。不久之
我正在尝试通过 Python 创建到 Heroku PostgreSQL 数据库的连接。我将 Windows10 与 Python 3.6.8 和 PostgreSQL 9.6 一起使用。 我从“ht
我有一个包含 2 列的数据框,我想根据两列之间的比较创建第三列。 所以逻辑是:第 1 列 val = 3,第 2 列 val = 4,因此新列值什么都没有 第 1 列 val = 3,第 2 列 va
我想知道如何调试 iphone 5 中的 css 问题。 我尝试使用 firelite 插件。但是从纵向旋转到横向时,火石占据了整个屏幕。 有没有其他方法可以调试 iphone 5 中的 css 问题
所以我有点难以理解为什么这不起作用。我正在尝试替换我正在处理的示例站点上的类别复选框。我试图让它做以下事情:未选中时以一种方式出现,悬停时以另一种方式出现(选中或未选中)选中时以第三种方式出现(而不是
Javascript CSS 问题: 我正在使用一个文本框来写入一个 div。我使用以下 javascript 获取文本框来执行此操作: function process_input(){
你好,我很难理解 P、NP 和多项式时间缩减的主题。我试过在网上搜索它并问过我的一些 friend ,但我没有得到任何好的答案。 我想问一个关于这个话题的一般性问题: 设 A,B 为 P 中的语言(或
你好,我一直在研究 https://leetcode.com/problems/2-keys-keyboard/并想到了这个动态规划问题。 您从空白页上的“A”开始,完成后得到一个数字 n,页面上应该
我正在使用 Cocoapods 和 KIF 在 Xcode 服务器上运行持续集成。我已经成功地为一个项目设置了它来报告每次提交。我现在正在使用第二个项目并收到错误: Bot Issue: warnin
我是一名优秀的程序员,十分优秀!