Django由于数据库版本原因导致数据库迁移失败解决办法

在django开发中,一般我们初始化一个项目之后,创建应用一般就会生成如下的目录:

bash 复制代码
django-admin startproject myproject
python manage.py startapp blog
XML 复制代码
myproject/
├── manage.py
└── myproject/
|    ├── __init__.py
|    ├── settings.py
|    ├── urls.py
|    └── wsgi.py
|___blog
    |___models.py
    |___......

其中model.py就是定义数据库表的文件。文件中的每个类就是就对应的数据库中的每张表。

比如models.py里面有如下一个类和对应的数据库中的关系如下所示:

python 复制代码
from django.db import models

class BlogPost(models.Model):
    """
    博客文章模型类
    数据库中对应的表名为: blog_post (Django 自动将类名转换为小写并用下划线连接)
    """
    title = models.CharField(max_length=200, verbose_name="文章标题")
    # 数据库对应: VARCHAR(200) 字段,NOT NULL 约束

    content = models.TextField(verbose_name="文章内容")
    # 数据库对应: TEXT 字段,NOT NULL 约束

    author = models.ForeignKey(
        'auth.User',
        on_delete=models.CASCADE,
        verbose_name="作者"
    )
    # 数据库对应: 外键字段,关联到 auth_user 表的 id 字段
    # 实际存储为 author_id 整数列

    created_at = models.DateTimeField(auto_now_add=True, verbose_name="创建时间")
    # 数据库对应: DATETIME 字段,NOT NULL
    # 仅在对象首次创建时自动设置为当前时间

    updated_at = models.DateTimeField(auto_now=True, verbose_name="更新时间")
    # 数据库对应: DATETIME 字段,NOT NULL
    # 每次保存对象时自动更新为当前时间

    is_published = models.BooleanField(default=False, verbose_name="是否发布")
    # 数据库对应: BOOLEAN/TINYINT(1) 字段,默认值为 0 (False)

    class Meta:
        verbose_name = "博客文章"
        verbose_name_plural = "博客文章"
        ordering = ['-created_at']
        # 数据库对应: 表将按 created_at 降序排列

执行

bash 复制代码
 python manage.py makemigrations 
 python migrate 

这里执行makemigrations的作用就在在对应的app目录下面生成migrations目录,里面会有一些python文件,记录了对model.py的修改。相当于git可以对models.py的每次修改做checkpoint。 举个例子。比如我在models.py里面第一次创建了数据库类,执行了makemigrations命令,这样就会在对应的migrations目录下面生成一个pyhton文件,编号从0001_.......py开始记录这一次的改动。后来我又修改了model.py里面的一些字段的命名。执行了makemigrations命令,这样就又会生成第二个0002_.......py文件。里面保存了这次对于这些字段修改的checkpoint。同时在django中,这个下面生成的文件名是易读的,可以从文件名大概知道改动的内容。

第二个执行完makemigrations命令之后,执行migrate就是把生成的哪些编号从0001开始的哪些文件的改动,同步到数据库中,该建表的建表。该修改字段的修改字段等等。这一步就是对数据库真正产生影响的步骤。

所以这里在做数据库迁移的时候,如果遇到迁移失败,我们是其实可以像git一样,回退迁移文件到最开始的时候也就是__inti__.py的时候,然后直接重新生成迁移文件,在做迁移

比如上面的代码执行之后,最后会在数据库中创建以下结构的表:

bash 复制代码
1.表名:blog_post

2.字段:

    id (自动创建的主键,INTEGER PRIMARY KEY AUTOINCREMENT)

    title (VARCHAR(200) NOT NULL)

    content (TEXT NOT NULL)

    author_id (INTEGER NOT NULL, 外键关联到 auth_user 表)

    created_at (DATETIME NOT NULL)

    updated_at (DATETIME NOT NULL)

    is_published (BOOLEAN/TINYINT(1) NOT NULL, 默认 0)

3.外键约束:

    FOREIGN KEY(author_id) REFERENCES auth_user(id) ON DELETE CASCADE
相关推荐
神奇的程序员5 小时前
从已损坏的备份中拯救数据
运维·后端·前端工程化
哥本哈士奇(aspnetx)5 小时前
Streamlit + LangChain 1.0 简单实现智能问答前后端
python·大模型
oden6 小时前
AI服务商切换太麻烦?一个AI Gateway搞定监控、缓存和故障转移(成本降40%)
后端·openai·api
我一定会有钱6 小时前
斐波纳契数列、end关键字
python
李慕婉学姐7 小时前
【开题答辩过程】以《基于Android的出租车运行监测系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·后端·vue
小鸡吃米…7 小时前
Python 列表
开发语言·python
m0_740043737 小时前
SpringBoot05-配置文件-热加载/日志框架slf4j/接口文档工具Swagger/Knife4j
java·spring boot·后端·log4j
星依网络7 小时前
yolov5实现游戏图像识别与后续辅助功能
python·开源·游戏程序·骨骼绑定
招风的黑耳8 小时前
我用SpringBoot撸了一个智慧水务监控平台
java·spring boot·后端
大佐不会说日语~8 小时前
Spring AI Alibaba 的 ChatClient 工具注册与 Function Calling 实践
人工智能·spring boot·python·spring·封装·spring ai