【问题标题】:Error models.py Django错误models.py Django
【发布时间】:2016-11-11 14:12:23
【问题描述】:

在 django 中创建迁移时出错

models.py

class StateBuyers(models.Model):
    name = models.CharField(max_length=100)

    def __unicode__(self):
        return self.name

    class Meta:
        db_table = "states"

class CountiesBuyers (models.Model):
    state = models.ForeignKey(StateBuyers, on_delete=models.CASCADE)
    name = models.CharField(max_length=100)

    def __unicode__(self):
        return self.name

    class Meta:
        db_table = "counties"


class CityBuyers (models.Model):
    state = models.ForeignKey(StateBuyers, on_delete=models.CASCADE)
    county = models.ForeignKey(CountiesBuyers, on_delete=models.CASCADE)
    name = models.CharField(max_length=100)

    def __unicode__(self):
        return self.name

    class Meta:
        db_table = "cities"

也许在这里我有错误 创建多个实例中的一个

class Buyers(models.Model):
    name = models.CharField(max_length= 50)
    state = models.ForeignKey(StateBuyers, related_name="Buyers", null=True, on_delete=models.CASCADE)
    city = models.ForeignKey(CityBuyers, related_name="Buyers", null=True, on_delete=models.CASCADE)
    phonenumber = models.CharField(max_length=15)
    email = models.EmailField (max_length= 50)
    notes = models.CharField(max_length=200)

    def __unicode__(self):
        return self.name

    class Meta:
        db_table = "buyers"

迁移的时候抛出这个错误 有什么想法吗?。

migration error

【问题讨论】:

  • 错误信息是什么?
  • 这个。 return self.cursor.execute(sql, params) django.db.utils.ProgrammingError: 关系“买家”不存在
  • 两个FK不能用同一个related_name,换一个再试试。
  • 同样的错误,有什么想法吗?
  • 您可能需要删除/编辑最后一个生成错误的迁移文件,这就是您收到相同错误的原因。

标签: python django migrate makemigrations


【解决方案1】:

有点离题,但你为什么不遵守约定?

  • 使用单数形式的简单模型名称
  • 如果与默认值相同,则不需要额外的参数
  • 如果县有州,为什么要复制州?任何性能提升?
class NameAsReprMixin(object):
    def __unicode__(self):
        return self.name

class State(models.Model, NameAsReprMixin):
    name = models.CharField(max_length=100)    


class County(models.Model, NameAsReprMixin):
    state = models.ForeignKey(State)
    name = models.CharField(max_length=100)


class City(models.Model, NameAsReprMixin):
    county = models.ForeignKey(County)
    name = models.CharField(max_length=100)


class Buyer(models.Model, NameAsReprMixin):
    name = models.CharField(max_length= 50)
    state = models.ForeignKey(State, related_name="buyers", null=True)
    city = models.ForeignKey(City, related_name="buyers", null=True)
    phone_number = models.CharField(max_length=15)
    email = models.EmailField(max_length= 50)
    notes = models.CharField(max_length=200)

然后:

# all city buyers
City.object.get(...).buyers.all()

# all state byuers
State.object.get(...).buyers.all()

【讨论】:

  • 好的兄弟,谢谢,现在我得到这个错误,有什么想法吗? i67.tinypic.com/24eddu0.png帮助!
  • @JesusRobles 现在试试,固定代码(我是从内存中写的),顺便说一句,代码和堆栈跟踪使用要点 - 好多了:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2020-02-08
  • 1970-01-01
  • 2021-01-08
  • 2017-10-30
  • 2011-02-06
  • 1970-01-01
  • 2011-04-10
相关资源
最近更新 更多