执行Django数据迁移,报错 1091
2019-10-13 22:12
931 查看
问题描述
今天在Pycharm 中的Terminal下,执行数据迁移操作时,第一步: Python manage.py makemigrations ,是没有任何问题,但就是在执行真正的数据迁移时,也就是第二步:Python manage.py migrate 时,报错,错误截图如下
大概的意思就是 错误代码1091,原因是 “无法删除'dt_id';请检查列/键是否存在”。
问题的解决
分析:
可能是数据库中的字段结构,已经完成了对此字段的修改,但是在执行数据迁移的时候,生成的某个日志文件(一般形如:0003_auto_20191011_2032.py),可能还有一些删除的字段
# Generated by Django 2.0.6 on 2019-10-11 12:32 from django.db import migrations, models class Migration(migrations.Migration): dependencies = [ ('modelapp', '0002_student'), ] operations = [ migrations.RemoveField( 14 model_name='student', 15 name='age', 16 ), 17 migrations.RemoveField( 18 model_name='student', 19 name='birthday', 20 ), 21 migrations.RemoveField( 22 model_name='student', 23 name='salary', 24 ), migrations.AlterField( model_name='student', name='tel', field=models.CharField(max_length=20), ), ]
如上图的红色字体问题部分,就是我们这个数据迁移时报错的原因,只要将红色字体部分注释掉即可
# Generated by Django 2.0.6 on 2019-10-11 12:32 from django.db import migrations, models class Migration(migrations.Migration): dependencies = [ ('modelapp', '0002_student'), ] operations = [ # migrations.RemoveField( # model_name='student', # name='age', # ), # migrations.RemoveField( # model_name='student', # name='birthday', # ), # migrations.RemoveField( # model_name='student', # name='salary', # ), migrations.AlterField( model_name='student', name='tel', field=models.CharField(max_length=20), ), ]
然后我们再次执行 Python manage.py migrate 的时候就能成功迁移数据了。
相关文章推荐
- 命令行执行Django脚本的方法
- 关于Django的contenttypes数据迁移
- django在命令行下执行的脚本使用ORM
- 【Python】django-celery执行定时任务
- django执行oracle sql报错ORA-00933: SQL command not properly ended
- 查看Django ORM执行的SQL语句
- django中使用paramiko远程执行命令
- Django 之 查看执行的sql语句
- 如何使用Django 启动命令行及执行脚本
- Django中执行迁移文件时的错误:You are trying to add a non-nullable 'xxx' to project without a default;we can't
- django执行原始查询sql,并返回Dict字典
- python django直接执行sql语句
- Django中的中间件机制和执行顺序
- 从命令行执行django数据库操作
- django中south做数据迁移
- 使用 django+celery+RabbitMQ 实现异步执行
- python web开发——Django执行查询
- django中执行py报错Requested setting DEFAULT_INDEX_TABLESPACE, but settings are not configured
- django+celery+docker搭建记录(3)- 使用django定时执行celery任务
- Django执行原始SQL