Django模特 - ' Pcaps.uuid'必须设置unique = True,因为它是由外键引用的

时间:2017-12-25 00:12:48

标签: sql django python-3.x django-models

本质上,我试图创建一些填充了pcaps属性的表。我收到了一个奇怪的错误。这是模型类中的代码:

class Pcaps(models.Model):
     uuid = models.CharField(max_length=50)
     filename = models.CharField(max_length=200, default='')
     datetime = models.DateTimeField(default=datetime.now, blank=True)
     filehash = models.ForeignKey(Malwares, to_field="filehash", 
 db_column="filehash")

class PcapsIps(models.Model):
    domainname = models.CharField(max_length=100)
    ip = models.CharField(max_length=100)
    uuid = models.ForeignKey(Pcaps, to_field="uuid", db_column="uuid")

class PcapsPorts(models.Model):
   number = models.CharField(max_length=100)
   uuid = models.ForeignKey(Pcaps, to_field="uuid", db_column="uuid")

有问题的错误如下:

错误:

analyser.PcapsIps.uuid: (fields.E311) 'Pcaps.uuid' must set unique=True 
because it is referenced by a foreign key.
analyser.PcapsPorts.uuid: (fields.E311) 'Pcaps.uuid' must set unique=True because it is referenced by a foreign key.

1 个答案:

答案 0 :(得分:3)

您必须了解外键如何工作,即在您使用的任何数据库系统中。外键是一个表(对应于Django模型)中的字段(或字段集合),它唯一地标识另一个(或相同)表的行。通常,这是通过主键完成的,因为它保证是唯一的。如果您有理由这样做,可以将echo $randnum设置为引用其他表/模型中的其他行,但该字段也必须是唯一的。因此,您需要:

to_field
编辑:哦,顺便说一句,如果您使用的是Django 1.8或更高版本,它现在有一个uuid = models.CharField(unique=True, max_length=50) 。见here