干货系列|Django的ORM迁移命令深度剖析
◆Django的makemigrations和migrate命令到底做了什么?
◆使用migrate命令为何出错?如何解决?
众所周知,Django是一个非常牛逼的web开发框架,他不仅拥有各种开箱即用的工具,更拥有强大的ORM框架,让我们在操作数据库的时候,就跟操作普通Python对象一样轻松和愉悦。ORM是特殊的类,这种类可以直接和数据库进行交互,并且表中的字段可以分别映射为ORM类上的属性。一般我们在使用ORM的顺序是,是先写好ORM类,然后再使用django的makemigrations来生成迁移脚本,再使用migrate命令来将生成的迁移脚本映射到数据库中。这种方式让我们创建表的sql语句都不用写了,直接一步到位。但是随着项目越来越复杂,参与项目的人越来越多,迁移脚本越来越乱,就很容易出现使用migrate的时候报错,相信经历过这种错误的心里都有一句MMP,但,看看我下面的解释,这句MMP就会化解了!
☻migrate怎么判断哪些迁移脚本需要执行:
他会将项目中migrations包下的迁移脚本的和数据库中django_migrations中的迁移脚本进行对比,如果发现数据库中,没有这个迁移脚本,那么就会执行这个迁移脚本。
☻migrate做了什么事情:
将相关的迁移脚本翻译成SQL语句,在数据库中执行这个SQL语句。
如果这个SQL语句执行没有问题,那么就会将这个迁移脚本的名字记录到django_migrations表中。
☻执行migrate命令的