Django python中的外键不匹配错误

问题描述

我是 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

我还创建了另外两个表; PersonGroup 但我后来删除了这两个表。现在,当我使用 python manage.py makemigrations 然后 python manage.py migrate

我仍然收到错误

django.db.utils.OperationalError:外键不匹配 - “shop_membership”引用“shop_person”

那么,我现在该怎么办?

解决方法

您应该仍然拥有包含 PersonGroup 模型的迁移文件。因此,您应该删除包含这些模型的迁移文件,但在删除它们之前,如果您之前已应用它们,请务必还原迁移。

要恢复迁移,您可以运行:

python manage.py migrate app_name xxxx_migration_before_the_one_you_want_to_un_apply

如果您刚刚开始使用该项目,您还可以通过运行以下命令恢复所有现有迁移:

python manage.py migrate app_name -- zero

这将恢复所有已应用的迁移,之后您只需删除所有迁移文件,然后重新运行 makemigrationsmigrate 命令以在单个文件中创建所有迁移并应用它们。

,

似乎 Membership 模型在某个时候引用了 Person 模型。现在您已经删除了 Person 模型,您可能需要将该字段设置为 nulll(Membership 中 Person 的外键)或完全删除 Membership 表(请注意,您将丢失数据)。