一、命令详解
1、作用于全局
python manage.py makemigrations 表示通知django即将做什么,并做一个记录,实际上并没有做
python manage.py migrate 真正开始创建数据库
2、作用于app或文件
需要注意的是这两个命令默认情况下是作用于全局,也就是对所有最新更改的models或者
migrations下面的迁移文件进行对应的操作,如果要想仅仅对部分app进行作用的话 ,则执行如下命令:
python manage.py makemigrations appname
通过makemigrations命令文件下多了一个001_initial的文件
这个文件里面的内容表示我们创建了一个Project这个模型类,并且指出这个类的成员属性id、name等以及定义,在models.py创建模型类,其中一个模型类对应的是一张数据表,然而这条命令并未真正添加数据库表
python manage.py migrate appname
此时在看数据库,project表已经在mysql中创建了
如果要想精确到某一个迁移文件则可以使用:
python manage.py migrate appname 0001_initial (文件名)
二、问题解答
由于之前生成过数据表,或者修改内容之后再次执行命令发现无法生成,例如:
解决方法:
1、删除001_initial文件
2、删除django_migrations表中记录
由于Django自带的一个表django_migrations表中已经将之前生成的表添加进入了,比如
3、重新执行上述两条命令
python manage.py makemigrations appname
python manage.py migrate appname
其他bug:
models.E028:::同一个表名在多个Model的db_table中使用
1、在 appname/models.py 文件中 meta 类设置managed=False
2、运行中会对managed=true的model进行检测,是否有多个model使用了同一个表名。