【问题标题】:django.db.utils.IntegrityError: UNIQUE constraint faileddjango.db.utils.IntegrityError:唯一约束失败
【发布时间】:2017-07-21 10:31:41
【问题描述】:

嗨,我是 django 框架的新手,我正试图从 2 天开始解决这个问题 python manage.py migrate 命令后出现此错误。 我不明白是什么问题?

模型.py

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


class BlogPost(models.Model):
    author = models.ForeignKey('auth.User')
    title = models.CharField(max_length=100,unique=True)
    text = models.TextField()
    created_date = models.DateTimeField(default=timezone.now)
    published_date = models.DateTimeField(blank=True,null=True)

def publish(self):
    self.published_date=timezone.now()
    self.save()

def __str__(self):
    return self.title

错误

  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages   /django/db/migrations/migration.py", line 129, in apply
operation.database_forwards(self.app_label, schema_editor, old_state, project_state)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/migrations/operations/fields.py", line 216, in database_forwards
schema_editor.alter_field(from_model, from_field, to_field)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/base/schema.py", line 515, in alter_field
old_db_params, new_db_params, strict)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/sqlite3/schema.py", line 262, in _alter_field
self._remake_table(model, alter_field=(old_field, new_field))
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/sqlite3/schema.py", line 206, in _remake_table
self.quote_name(model._meta.db_table),
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/base/schema.py", line 120, in execute
cursor.execute(sql, params)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/utils.py", line 80, in execute
return super(CursorDebugWrapper, self).execute(sql, params)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/utils.py", line 65, in execute
return self.cursor.execute(sql, params)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/utils.py", line 94, in __exit__
six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/utils/six.py", line 685, in reraise
raise value.with_traceback(tb)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/utils.py", line 65, in execute
return self.cursor.execute(sql, params)
  File "/home/letsperf/.conda/envs/MyDjangoEnv/lib/python3.5/site-packages/django/db/backends/sqlite3/base.py", line 328, in execute
return Database.Cursor.execute(self, query, params)
django.db.utils.IntegrityError: UNIQUE constraint failed: social_blogpost.title

请帮助我困惑!

【问题讨论】:

  • 这个错误显然是直截了当的。您已将 title 定义为唯一的,Django 不会让您为唯一字段保存相同的值两次。
  • 现在我该怎么办?
  • 你想做什么?如果你不想要 unique 约束,你可以删除它
  • 我希望标题是唯一的,没有人可以再次使用它,您知道还有其他方法吗?
  • 您在数据库中已经有一个具有相同标题的对象。删除或编辑它。

标签: python django


【解决方案1】:

根据Django documentation,这是问题的总结;

应用“普通”迁移,将唯一的不可为空的字段添加到 具有现有行的表将引发错误,因为使用的值 填充现有行只生成一次,从而打破 唯一约束。

【讨论】:

    猜你喜欢
    • 2015-06-05
    • 2016-04-11
    • 2019-12-31
    • 1970-01-01
    • 2022-01-21
    • 2017-04-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多