执行Django项目的数据库迁移命令时报错:(1050, “Table ‘django_session‘ already exists“);如何破?

一、问题描述:

当我们写Django时,由于自己的操作不当,导致执行数据库迁移命令时报错,报错的种类有很多,例如:

  • 迁移文件冲突:可能你有多个迁移文件试图创建同一个表。
  • 数据库状态与迁移文件不同步:你的数据库中已经存在某些表,但迁移文件或 Django 的迁移记录(存储在 django_migrations 表中)不匹配。
  • 重复运行初始迁移:你可能多次运行了初始的迁移命令,导致 Django 试图重新创建已经存在的表。

这篇文章将用于不定期更新所遇到的错误和解决办法。

二、迁移命令如下:

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

三、错误整理:

错误一:
复制代码
```python
pymysql.err.OperationalError: (1050, "Table 'django_session' already exists")
```
  • 解决办法:

  • 在数据库中找到Django 的迁移记录(存储在 django_migrations 表中),删除掉相关的表记录,我这里是删除掉sessions这条记录。如果你的users表有问题,那就删除掉所有users相关的记录(原表中的数据不会受到影响)。

  • 删除掉相关项目文件夹migrations下除了__init__.py的所有文件,例如users下:

  • 然后依次执行下面的语句

  • 如果你确定数据库中的表是正确的,但迁移记录不正确,你可以使用 --fake 选项来标记迁移为已完成。

    python 复制代码
    python manage.py makemigrations
    python manage.py migrate --fake  # --fake
  • 查看结果

错误二:

错误搜集中...

相关推荐
杰瑞学AI2 分钟前
LeetCode详解之如何一步步优化到最佳解法:21. 合并两个有序链表
数据结构·python·算法·leetcode·链表·面试·职场和发展
攻城狮7号10 分钟前
Python爬虫第5节-urllib的异常处理、链接解析及 Robots 协议分析
爬虫·python·python爬虫
java1234_小锋15 分钟前
一周学会Pandas2 Python数据处理与分析-Jupyter Notebook安装
开发语言·python·jupyter·pandas
skywalk816318 分钟前
unittest测试模块:Python 标准库中的单元测试利器
开发语言·python·unittest
小小鸭程序员2 小时前
在Spring Boot中实现图片上传和修改
java·数据库·python·mysql·spring
怪味&先森3 小时前
利用pytorch对加噪堆叠自编码器在MNIST数据集进行训练和验证
人工智能·pytorch·python
Uncertainty!!3 小时前
在huggingface上制作小demo
开发语言·python·机器学习·huggingface
gqkmiss4 小时前
Browser-use:基于 Python 的智能浏览器自动化 AI 工具调研与实战
人工智能·python·ai·自动化·浏览器
Bruce_Liuxiaowei4 小时前
基于Python Flask快速构建网络安全工具资源库的Web应用实践
python·web安全·flask
qq_273900234 小时前
Pytorch torch.nn.utils.rnn.pad_sequence 介绍
人工智能·pytorch·python·rnn·深度学习