django.db.utils.OperationalError: (1050, “Table ‘你的表名‘ already exists“)

这个错误意味着 Django 尝试执行迁移时,发现数据库中已经有一张叫 你的表名的表了,但这张表不是通过 Django 当前的迁移系统管理的,或者迁移状态和数据库实际状态不一致。

🧠 可能出现这个问题的几种情况:

复制代码
1.你手动创建过这张表;
2.你曾经运行过迁移,但删除了迁移文件,没有同步清除数据库记录;
3.数据库是旧的,或者有测试残留;

✅ 解决方法(几个选项):

✅ 方案一:数据库表已存在、但你确定是正确的表结构,可以"假装"迁移已执行

运行:

复制代码
python manage.py migrate --fake core

这会告诉 Django:"我确认这张表已经存在了,不要再执行创建操作了,但请把迁移状态标记为已完成。"

你也可以针对某个特定迁移,例如:

复制代码
python manage.py migrate core 0019 --fake

✅ 方案二:如果你是本地测试环境,可以重建数据库

如果你是本地开发测试,还可以彻底清除并重建数据库:

复制代码
# 警告:这会清除所有数据
python manage.py flush
# 或者更狠:
python manage.py migrate --fake core zero
# 然后重新迁移
python manage.py migrate

✅ 方案三:手动删除表(慎用)

如果你确定这张表没有用、是残留的:

复制代码
DROP TABLE xss_inventory_log;

然后重新执行迁移:

复制代码
python manage.py migrate

📝 建议

使用 --fake 方式是最常见的解决方案,尤其适合你手动同步了数据库,但 Django 认为没执行。

在多人协作或生产环境中,建议不要轻易删表或强制迁移,防止数据丢失。

相关推荐
码界奇点4 小时前
基于Django的超市管理系统设计与实现
数据库·python·django·sqlite·毕业设计·源代码管理
B站_计算机毕业设计之家6 小时前
AI大模型:Deepseek美食推荐系统 机器学习 协同过滤推荐算法+可视化 Django框架 大数据毕业设计(源码)✅
python·算法·机器学习·数据分析·django·推荐算法·美食
yq1982043011567 小时前
构建高可用资源导航平台:基于Django+Scrapy的分布式架构实践
分布式·scrapy·django
森爱。8 小时前
web开发全家桶(django+前端+数据库)
前端·python·django
luoluoal1 天前
基于opencv的疲劳检测系统(源码+文档)
python·mysql·django·毕业设计·源码
ktoking1 天前
Stock Agent AI 模型的选股器实现 [七]
人工智能·python·django
BYSJMG2 天前
2026计算机毕设推荐:基于大数据的车辆二氧化碳排放量可视化分析系统
大数据·vue.js·python·mysql·django·课程设计
WangYaolove13143 天前
基于opencv的疲劳检测系(源码+文档)
python·mysql·django·毕业设计·源码
luoluoal4 天前
基于python的人脸识别的酒店客房入侵检测系统(源码+文档)
python·mysql·django·毕业设计·源码
Blossom.1184 天前
从数字大脑到物理实体:具身智能时代的大模型微调与部署实战
人工智能·python·深度学习·fpga开发·自然语言处理·矩阵·django