干货系列|Django的ORM迁移命令深度剖析
◆Django的makemigrations和migrate命令到底做了什么?
◆使用migrate命令为何出错?如何解决?
众所周知,是一个非常牛逼的开发框架,他不仅拥有各种开箱即用的工具,更拥有强大的框架,让我们在操作数据库的时候,就跟操作普通对象一样轻松和愉悦。是特殊的类,这种类可以直接和数据库进行交互,并且表中的字段可以分别映射为类上的属性。一般我们在使用的顺序是,是先写好类,然后再使用的来生成迁移脚本,再使用命令来将生成的迁移脚本映射到数据库中。这种方式让我们创建表的语句都不用写了,直接一步到位。但是随着项目越来越复杂,参与项目的人越来越多,迁移脚本越来越乱,就很容易出现使用的时候报错,相信经历过这种错误的心里都有一句MMP,但,看看我下面的解释,这句MMP就会化解了!
☻migrate怎么判断哪些迁移脚本需要执行:
他会将项目中包下的迁移脚本的和数据库中中的迁移脚本进行对比,如果发现数据库中,没有这个迁移脚本,那么就会执行这个迁移脚本。
☻migrate做了什么事情:
将相关的迁移脚本翻译成语句,在数据库中执行这个语句。
如果这个语句执行没有问题,那么就会将这个迁移脚本的名字记录到表中。
☻执行migrate命令的时候报错的解决办法
原因:
执行命令会报错的原因是:数据库的表中的迁移版本记录和项目中的迁移脚本不一致导致的。
解决办法:
使用参数:只会将迁移版本的版本号记录到中,而并不会执行这个迁移脚本。所以如果是数据库中的表和模型都已经完成了映射,但是版本号对不上,那么可以使用这种方式解决。
终极解决方案:如果代码中的迁移脚本和数据库中的迁移脚本实在太多,就是搞不清了。那么这时候就可以使用以下终极解决方案:
▲终极解决方案原理:就是将之前的那些迁移脚本都不用了。重新来过。要将出问题的app下的所有模型和数据库中表保持一致,重新映射。
▲将出问题的app下的所有模型,都和数据库中的表保持一致。
▲将出问题的app下的所有迁移脚本文件都删掉。再在django_migrations表中将出问题的app相关的迁移记录都删掉。
▲使用makemigrations,重新将模型生成一个迁移脚本。
▲使用migrate --fake-initial参数,将刚刚生成的迁移脚本,标记为已经完成(因为这些模型相对应的表,其实都已经在数据库中存在了,不需要重复执行了。)
▲可以做其他的映射了。
领取专属 10元无门槛券
私享最新 技术干货