django中的UNIQUE约束失败错误

时间:2017-08-11 16:50:10

标签: python django

我在django项目中的迁移有点问题。 我有一个models.py文件,在第一次迁移后,我有一个想法添加新字段:

slug_kat = models.SlugField(max_length=255, unique=True, verbose_name='Odnośnik', default='')

当我写python manage.py makemigrations时,系统会向我显示以下内容: Add field slug_kat to kategorie 之后我写了命令python manage.py migrate firmy并繁荣......错误:

django.db.utils.IntegrityError: UNIQUE constraint failed: firmy_kategorie.slug_kat

以下是我的 models.py 文件,其中包含新行slug_kat:

from django.db import models
from django.utils import timezone


class Kategorie(models.Model):
    glowna = models.CharField(max_length=150, verbose_name='Kategoria')
    slug_kat = models.SlugField(max_length=255, unique=True, verbose_name='Odnośnik', default='')

    class Meta:
        verbose_name='Kategoria'
        verbose_name_plural='Kategorie'

    def __str__(self):
        return self.glowna


class Witryna(models.Model):
    nazwa = models.CharField(default="", max_length=150, verbose_name = 'Nazwa strony')
    adres_www = models.CharField(max_length=70, verbose_name='Adres www')
    slug = models.SlugField(max_length=250, verbose_name='Przyjazny adres url')
    email = models.CharField(max_length=100, verbose_name='Adres e-mail')
    text = models.TextField(max_length=3000, verbose_name='Opis strony')
    kategoria = models.ForeignKey(Kategorie, verbose_name='Kategoria')
    data_publikacji = models.DateTimeField(blank=True, null=True, verbose_name='Data publikacji')

    class Meta:
        verbose_name='Strona www'
        verbose_name_plural = 'Strony www'

    def publikacja(self):
        self.data_publikacji=timezone.now()
        self.save()

    def __str__(self):
        return self.nazwa

1 个答案:

答案 0 :(得分:1)

问题是您提供的是默认值以及unique = True

因此django将默认值作为all的值,不能采用唯一的

所以要么使用这个

slug_kat = models.SlugField(max_length=255, unique=True, verbose_name='Odnośnik')

slug_kat = models.SlugField(max_length=255,  verbose_name='Odnośnik', default='')