django数据库migrate失败的解决方法
2018-01-30 09:54
351 查看
Django是一个MVC架构的web框架,其中,数据库就是“Module”。使用这种框架,我们不必写一条SQL语句,就可以完成对数据库的所有操作。在之前的Django版本中,我们像操作本地对象那样操作数据对象,在更改保存之后,执行
python manage.py makemigrations (这个命令会根据你对数据库做出的更改生成操作数据库的python脚本)
python manage.py migrate (这个命令会执行python脚本)
我遇到的问题是,执行makemigrations没有问题,但是执行migrate的时候有问题。于是我修改了modules.py中错误的代码,再次执行,却一直出问题。提示如下:
我删掉了makemigrations生成的代码,然后重新使用makemigrations生成脚本,还是出错。
原来,这是由于出错的时候,migrate命令已经执行了部分脚本,也就是说,to_user_id属性已经被操作过了,在数据库中,已经无需再操作了,所以执行migrate命令重新更新makemigrations的脚本会出错。
重新生成makemigrations不行,执行migrate也只会全部执行。那么我们只好把数据库恢复到出错的那次执行前面的样子。
恢复方法:在project/app/migrations下有每次对数据操作所生成的脚本。找到出错那次脚本,打开脚本,可读性还是很高的,将所对应的数据库更改还原(当然得使用mysql语句了)。
然后删掉这次migration,重新make 然后执行。
实在不行,还有一个万不得已的办法。几乎所有的数据库错误都可以用这个方法解决:
将migrations文件夹下的文件除了__init__.py全部删掉,然后将数据库drop掉,重新建数据库。然后make,migrate,就可以使用一个新的数据库(但愿你永远用不到这个方法)。
python manage.py syncdb命令来同步数据库,在我使用的1.9.2版本中,需要依次执行一下步骤:
python manage.py makemigrations (这个命令会根据你对数据库做出的更改生成操作数据库的python脚本)
python manage.py migrate (这个命令会执行python脚本)
我遇到的问题是,执行makemigrations没有问题,但是执行migrate的时候有问题。于是我修改了modules.py中错误的代码,再次执行,却一直出问题。提示如下:
1 | django.db.utils.OperationalError: (1060, "Duplicate column name 'to_user_id'") |
原来,这是由于出错的时候,migrate命令已经执行了部分脚本,也就是说,to_user_id属性已经被操作过了,在数据库中,已经无需再操作了,所以执行migrate命令重新更新makemigrations的脚本会出错。
解决办法
重新生成makemigrations不行,执行migrate也只会全部执行。那么我们只好把数据库恢复到出错的那次执行前面的样子。恢复方法:在project/app/migrations下有每次对数据操作所生成的脚本。找到出错那次脚本,打开脚本,可读性还是很高的,将所对应的数据库更改还原(当然得使用mysql语句了)。
然后删掉这次migration,重新make 然后执行。
实在不行,还有一个万不得已的办法。几乎所有的数据库错误都可以用这个方法解决:
将migrations文件夹下的文件除了__init__.py全部删掉,然后将数据库drop掉,重新建数据库。然后make,migrate,就可以使用一个新的数据库(但愿你永远用不到这个方法)。
相关文章推荐
- django数据库migrate失败的解决方法解析
- django数据库migrate失败的解决方法
- 附加数据库失败 操作系统错误5:5拒绝访问 错误5120 解决方法
- SQL附加数据库失败问题的解决方法
- SQL Server 2014 无法打开用户默认数据库 登录失败错误4064的解决方法
- SQL Server 2005 创建数据库失败提示“Collation is not valid”解决方法
- ASP.net出现“访问IIS元数据库失败”解决方法是什么?
- 数据库还原失败解决方法
- python3.4环境下新建django应用失败报错"计算机中丢失python27.dll"的解决方法
- SQL Server 2008附加数据库失败:无法打开物理文件拒绝访问解决方法
- 对于访问IIS元数据库失败的解决方法
- 访问IIS元数据库失败解决方法(转)
- Asp.net还原数据库失败的解决方法
- 基于pip install django失败时的解决方法
- dedecms搬家时出现数据库导入失败的解决方法
- SQL Server 2005 创建数据库失败提示“Collation is not valid”解决方法
- 关于访问IIS元数据库失败的解决方法
- 【Yii2.0.7】 ./yii migrate 执行数据库迁移时出现2002错误的解决方法!
- 访问IIS元数据库失败解决方法
- 站长篇----远程连接数据库失败的解决方法