您的位置:

深入理解makemigrations

一、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