django迁移脚本
2024-08-30 15:11:48
执行migrate报错的解决办法:
想知道migrate为什么报错,需要先了解migrate到底做了什么事情
migrate做了什么事情?
1.将相关的迁移脚本翻译成sql语句,然后在数据库中执行
2.如果sql语句执行没有问题,那么会将相关的迁移脚本的名字记录到数据库中django_migrations表中
migrate怎么判断哪些迁移脚本需要执行?
migrate会将代码中的迁移脚本和数据库中的迁移脚本做对比,如果发现数据库中没有这个迁移脚本,便会执行
原因
执行migrate报错,是因为django项目中的迁移脚本和数据库里的django_migrations迁移脚本记录不一致导致报错
解决办法
使用--fake参数
首先对比数据库中的迁移脚本和代码中的迁移脚本,找到哪个不同,然后使用--fake,将代码中的迁移脚本添加到'django_migrations'里,但是不会执行sql语句,这样就避免每次执行migrate的时候重复调用迁移脚本
终极解决方案
如果代码中的迁移脚本和数据库中的脚本实在太多,就是搞不清了,那么这个时候可以用终极解决方案
1.将代码中的迁移脚本和数据库中的迁移脚本全部删除
2.确保app中models的字段和数据库中的字段一致
3.使用 python manager.py makemigrations重新生成迁移脚本
4.使用python manager.py migrate --fake-initial将刚刚生成的迁移脚本,标记为已完成(因为这些模型相对应的表,其实在数据库里都已经存在了,不需要重复执行)
最新文章
- InfoCube信息立方体的优化
- CCNA网络工程师学习进程(3)常规网络设计模型与基本的网络协议
- linux shell 输入密码不显示
- JS回调函数(callback)
- Windows 2008 故障转移群集介绍
- cefSharp 设置运行时系统语言
- 用PS给图标添加外发光效果
- 【ALB学习笔记】基于事件触发方式的串行通信接口数据接收案例
- WebService/WCF/WebAPI区别
- TCP的十一种状态与三次握手分析(有图)
- jQuery结合lhgdialog弹出窗口,关闭时出现没有权限错误
- word 2013 粘贴的图片自适应大小
- freckles
- ASP.NET MVC下使用AngularJs语言(一):Hello your name
- 保留最新N份备份目录脚本
- Bootstrap3基础 btn-primary/warning... 三类按钮的六种样式
- 最短路(hdu2544)Dijkstra算法二
- 《剑指offer》第六题(重要!从尾到头打印链表)
- java poi给sheet表格中的某个单元格添加批注
- python安装报错:Microsoft Visual C++ 14.0 is required