Получение django.db.utils.IntegrityError: повторяющееся значение ключа нарушает ограничение уникальности, но значение не существует

#django #postgresql #django-models #django-orm #unique-constraint

#django #postgresql #django-модели #django-orm #уникальное ограничение

Вопрос:

Я использую PostgreSQL с Django, и я пытался получить некоторый объект из БД с помощью Django ORM.

 Medicine.objects.get(unique_item_id=26775)
  

Но во время выборки я столкнулся с ошибкой -> item_medicine.models.DoesNotExist: Medicine matching query does not exist.

Затем я попытался вставить то же самое, используя Django ORM.

 Medicine.objects.create(unique_item_id=26775)
  

Но снова я получаю ошибку psycopg2.errors.UniqueViolation: duplicate key value violates unique constraint "item_medicine_medicine_unique_item_id_key" DETAIL: Key (unique_item_id)=(26775) already exists.

В моих моделях я добавил unique=True unique_item_id поле for .

Я не знаю, почему это происходит. Я пробовал ответы, приведенные на похожие сообщения, но ничего не сработало.

Трассировка:

 Traceback (most recent call last):
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/backends/utils.py", line 64, in execute
    return self.cursor.execute(sql, params)
psycopg2.errors.UniqueViolation: duplicate key value violates unique constraint "item_medicine_medicine_unique_item_id_key"
DETAIL:  Key (unique_item_id)=(26775) already exists.
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/IPython/core/interactiveshell.py", line 2963, in run_code
    exec(code_obj, self.user_global_ns, self.user_ns)
  File "<ipython-input-4-46fdec6a582b>", line 1, in <module>
    Medicine.objects.create(unique_item_id=26775)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/query.py", line 394, in create
    obj.save(force_insert=True, using=self.db)
  File "/home/rohit/Projects/medicine/item_medicine/models.py", line 58, in save
    super(Medicine, self).save(*args, **kwargs)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/base.py", line 808, in save
    force_update=force_update, update_fields=update_fields)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/base.py", line 838, in save_base
    updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/base.py", line 924, in _save_table
    result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/base.py", line 963, in _do_insert
    using=using, raw=raw)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/query.py", line 1076, in _insert
    return query.get_compiler(using=using).execute_sql(return_id)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/models/sql/compiler.py", line 1112, in execute_sql
    cursor.execute(sql, params)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/backends/utils.py", line 79, in execute
    return super(CursorDebugWrapper, self).execute(sql, params)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/backends/utils.py", line 64, in execute
    return self.cursor.execute(sql, params)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/utils.py", line 94, in __exit__
    six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/utils/six.py", line 685, in reraise
    raise value.with_traceback(tb)
  File "/home/rohit/virtualenvs/envmedicine/lib/python3.6/site-packages/django/db/backends/utils.py", line 64, in execute
    return self.cursor.execute(sql, params)
django.db.utils.IntegrityError: duplicate key value violates unique constraint "item_medicine_medicine_unique_item_id_key"
DETAIL:  Key (unique_item_id)=(26775) already exists.
  

Заранее спасибо, ребята!!

Комментарии:

1. Я не уверен, что вызвало проблему, но вы пробовали Medicine.objects.filter(unique_item_id=26775).first() ?

2. Я попробовал filter, но он возвращает пустой набор запросов

3. попробуйте это Medicine.objects.get(unique_item_id_id =26775)

4. Нет, поле ошибки получения не существует

5. Это немного странно, это происходит только с PostgreSQL? Если да, то можно ли его воспроизвести в новом проекте ? @RohitChopra

Ответ №1:

Если вы выполняете какую-либо фильтрацию в своем Medicine.objects менеджере, вы, вероятно, столкнетесь с этой проблемой. Например, предположим, что у вас определены следующие модель и менеджер.

 class SoftDeleteManager(models.Manager):
    def get_queryset(self):
        return super().get_queryset().filter(deleted_at=None)

class Medecine(models.Model):
    ...
    unique_item_id = models.IntegerField(unique=True)
    deleted_at = models.DateTimeField(null=True)

    objects = SoftDeleteManager()

conflicting = Medecine.objects.create(unique_item_id=26775, deleted_at=some_datetime)

Medecine.objects.get(unique_item_id=26775)  # Results in DoesNotExist
Medecine.objects.create(unique_item_id=26775) # Results in IntegrityError
  

Если это не так, то у вас может быть поврежден индекс PostgreSQL.

Я бы посоветовал вам попробовать запустить REINDEX команду на вашем столе

REINDEX TABLE item_medicine_medicine

Комментарии:

1. Действительно, и я бы посоветовал проверить, что происходит непосредственно в БД, используя psql в консоли или pgAdmin. выберите * из лекарства, где unique_item_id = 26775.

2. «… любой вид фильтрации… тогда вы, вероятно, столкнетесь с этой проблемой …» Не могли бы вы объяснить, почему? В чем основная причина? Я знаю, что это есть в вашем примере, но краткое объяснение было бы очень полезно. 🙂

3. Ошибка фильтрации базового менеджера также упоминается в документах: don-t-filter-away-any-results-in-this-type-of-manager-subclass