Постоянно получаю сообщение об ошибке «Не удалось выполнить ограничение FOREIGN KEY» IntegrityError, когда я пытаюсь удалить сообщение - PullRequest
0 голосов
/ 04 июля 2019

Каждый раз, когда я пытаюсь удалить сообщение, я получаю эту ошибку, но моя кнопка удаления использовалась раньше. Я думаю, что это как-то связано с атрибутом on_delete, но я несколько раз менял его значение, но оно все равно не работало.

// models.py

from django.db import models
from django.conf import settings
from django.urls import reverse


User = settings.AUTH_USER_MODEL

class PostManager(models.Manager):
    def search(self, query):
        qs = self.get_queryset().filter(title__icontains=query)
        if qs:
            return qs
        return None

    def get_by_id(self, id):
        qs = self.get_queryset().filter(id=id)
        if qs.count() == 1:
            return qs.first()
        else:
            return None     


# Create your models here.
class PostModel(models.Model):
    user = models.ForeignKey(User, default=1, on_delete=models.CASCADE)
    title = models.CharField(max_length=50)
    message = models.TextField()
    date = models.DateTimeField(auto_now_add=True)
    likes = models.ManyToManyField(User, blank=True, related_name='post_likes')


    def __str__(self):
        return self.title

    objects = PostManager()

    def get_total_likes(self):
        return self.likes.count()   

    def get_absolute_url(self):
        return reverse("birdpost:detail", kwargs={"id": self.id})

    def get_like_url(self):
        return reverse("birdpost:like-toggle", kwargs={"id": self.id})

    def get_delete_url(self):
        return reverse("birdpost:delete_post", kwargs={"id": self.id})

// views.py

def del_post(request, id):
    obj = get_object_or_404(PostModel, id=id)
    if request.user != obj.user:
        print("Ooh no looks like this post is not yours... ")
    else:
        obj.delete()

    return redirect("home")

Окружающая среда:

Способ запроса: GET URL запроса: http://localhost:8000/post/4/delete

Django Версия: 2.2.1 Версия Python: 3.6.8 Установленные приложения:

['django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'accounts',
 'birdpost',
 'search']

Установленное промежуточное ПО:

['django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']

Traceback:

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/backends/base/base.py" in _commit
  240.                 return self.connection.commit()

The above exception (FOREIGN KEY constraint failed) was the direct cause of the following exception:

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/core/handlers/exception.py" in inner
  34.             response = get_response(request)

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  115.                 response = self.process_exception_by_middleware(e, request)

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  113.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/home/grey/Desktop/python/birds/src/birdpost/views.py" in del_post
  104.      obj.delete()

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/models/base.py" in delete
  919.         return collector.delete()

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/models/deletion.py" in delete
  318.                             sender=model, instance=obj, using=self.using

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/transaction.py" in __exit__
  240.                         connection.commit()

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/backends/base/base.py" in commit
  262.         self._commit()

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/backends/base/base.py" in _commit
  240.                 return self.connection.commit()

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/utils.py" in __exit__
  89.                 raise dj_exc_value.with_traceback(traceback) from exc_value

File "/home/grey/Desktop/python/birds/virtualenv/lib/python3.6/site-packages/django/db/backends/base/base.py" in _commit
  240.                 return self.connection.commit()

Exception Type: IntegrityError at /post/4/delete
Exception Value: FOREIGN KEY constraint failed

Ответы [ 2 ]

0 голосов
/ 05 июля 2019

Я удалил значение по умолчанию = 1, как сказал @ Na'aman Hirschfeld, и удалил все мои миграции и базу данных.И теперь работает нормально.

0 голосов
/ 05 июля 2019

Попробуйте удалить значение по умолчанию = 1.Я не знаю, стоит ли устанавливать значение по умолчанию без поля выбора.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...