问题描述
我是 Django 的新手,在迁移我的项目时遇到错误“外键不匹配错误”。 我的项目中有以下模型:
from django.db import models
# Create your models here.
class Product(models.Model):
product_id=models.AutoField
product_name=models.CharField(max_length=50)
product_desc=models.CharField(max_length=50)
product_date=models.DateField()
product_image=models.ImageField(upload_to="shop/images",default="")
def __str__(self):
return self.product_name
class User(models.Model):
user_email=models.EmailField(primary_key=True)
user_name=models.CharField(max_length=20)
def __str__(self):
return self.user_email
class Student(models.Model):
course=(
('MS','MS'),('BS','BS')
)
student_name=models.CharField(max_length=40)
student_roll=models.IntegerField(primary_key=True)
student_course=models.CharField(max_length=100,choices=course)
class Order(models.Model):
user=models.ForeignKey(Student,on_delete=models.CASCADE)
id=models.IntegerField(primary_key=True)
date=models.DateField()
time=models.TimeField()
price=models.FloatField()
def __str__(self):
return str(self.id)
class Teacher(models.Model):
user_email=models.EmailField(primary_key=True)
user_name=models.CharField(max_length=20)
def __str__(self):
return self.user_email
我还创建了另外两个表; Person 和 Group 但我后来删除了这两个表。现在,当我使用 python manage.py makemigrations 然后 python manage.py migrate
我仍然收到错误;
django.db.utils.OperationalError:外键不匹配 - “shop_membership”引用“shop_person”
那么,我现在该怎么办?
解决方法
您应该仍然拥有包含 Person
和 Group
模型的迁移文件。因此,您应该删除包含这些模型的迁移文件,但在删除它们之前,如果您之前已应用它们,请务必还原迁移。
要恢复迁移,您可以运行:
python manage.py migrate app_name xxxx_migration_before_the_one_you_want_to_un_apply
如果您刚刚开始使用该项目,您还可以通过运行以下命令恢复所有现有迁移:
python manage.py migrate app_name -- zero
这将恢复所有已应用的迁移,之后您只需删除所有迁移文件,然后重新运行 makemigrations
和 migrate
命令以在单个文件中创建所有迁移并应用它们。
似乎 Membership 模型在某个时候引用了 Person 模型。现在您已经删除了 Person 模型,您可能需要将该字段设置为 nulll(Membership 中 Person 的外键)或完全删除 Membership 表(请注意,您将丢失数据)。