首先记录我的学习过程:
1、python manage.py makemigrations
# 基于当前的model创建新的迁移策略文件
2、python manage.py migrate
#用于执行迁移动作,具有syncdb的功能
我就是在第2步出错的(1050, “Table ‘table’ already exists”)。
然后我是这样解决的,参考
1、python manage.py dbshell
#进入数据库查看django_migrations的迁移记录;
2、select * from django_migrations where app='myapp';
#根据自己的app名称查找迁移记录;
3、实际情况各异,这里我的记录仅供参考:
3.1、delete from django_migrations where app='myapp';
删除myapp
的所有迁移记录
我自己学习的时候就不清楚myapp到底是什么东西,如果你和我一样蠢,你可以这样做:
select * from django_migrations;
其中在app那一列,你会发现就有你想要的myapp。
3.2、新开命令行,执行python manage.py migrate myapp --fake
,目的是为了默认迁移所有的修改,并存储到数据库,
3.3、此时再次执行python manage.py migrate myapp
,会出现:No migrations to apply.
,因为--fake
已经完成了全部迁移。
3.4、此时查看数据库,执行python manage.py dbshell
,
查看迁移数据:select * from django_migrations where app='myapp';
。
4、实际项目需要执行python manage.py dbdefaults
,这一步我仅作为自己学习的记录,大家不需要,也不要操作。
自己能懂,就是写不出来,表达不清楚,先这样吧,后面再补充。