一、makemigrations命令
makemigrations是Django中的命令之一,它的主要作用是根据models.py文件中的内容创建一个migration文件,以便后续的执行migrate命令来同步数据库结构和models.py文件的定义。
使用makemigrations命令可以轻松地更改数据库模型而不会影响到已有的数据。它将自动在数据库中创建一个新的迁移,这个迁移可以让你安全地变更模型定义,并且能保留历史记录以便重复安装或升级。
makemigrations命令可以被执行多次,每次执行会对比models.py文件和当前已有的迁移记录,生成新的迁移文件。
python manage.py makemigrations
二、makemigrations怎么读
makemigrations命令中的“make”单词意思是“创造”或“制作”,“migrations”单词表示“迁移”。合在一起表示“创建一个数据库迁移记录”。
三、migration
一个migration文件对应着一个数据库迁移记录(可以理解为对数据库操作的一个版本),其中包含了所有关于对数据库的修改和变更的信息。
当执行makemigrations命令时,Django会检测models.py和已有的迁移记录文件并生成一个新的migration文件。
这个migration文件包含了关于数据库结构变更的详细信息,包括了创建,删除或修改数据库表结构等操作,同时也包含了某些操作所需的数据变更。
# 从一个已有的模型生成迁移文件 python manage.py makemigrations yourappname
四、migrate
migrate命令是Django中用来同步数据库结构与models.py文件的定义的命令。
当执行migrate命令时,Django会查找所有已经存在的migration文件以及它们包含的关于数据库结构变更的详细信息,然后应用这些变更来更新数据库的结构。
此外,迁移还可以进行数据填充,固定数据更新等操作。
# 执行迁移 python manage.py migrate
五、legislation
当创建迁移文件时,需要遵守一定的规则和准则。这些规则通常称为“legislation”。
Django migration的legislation规则包括:每个model必须定义在models.py文件中,每个model必须有一个primary键,对于外键、多对多等关系,必须使用ForeignKey和ManyToManyField等Django提供的方式进行定义。
在编写models.py文件和迁移时遵守这些规则,可以有效避免在应用迁移时出现问题。
完整示例代码
# models.py文件 from django.db import models class Article(models.Model): title = models.CharField(max_length = 255) content = models.TextField() class Comment(models.Model): article = models.ForeignKey(Article, on_delete = models.CASCADE) content = models.TextField() # 生成迁移文件 python manage.py makemigrations yourappname # 应用迁移文件 python manage.py migrate