python - Django 2.1.7,完整性错误,外键约束失败

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

我对 User 和 Post 模型之间的外键关系有问题。或者更确切地说,在为自定义用户模型创建外键时,出现错误:

回溯:

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\backends\base\base.py" in _commit
  239.                 return self.connection.commit()

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

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\core\handlers\exception.py" in inner
  34.             response = get_response(request)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\core\handlers\base.py" in _get_response
  126.                 response = self.process_exception_by_middleware(e, request)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\core\handlers\base.py" in _get_response
  124.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\contrib\admin\options.py" in wrapper
  604.                 return self.admin_site.admin_view(view)(*args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\utils\decorators.py" in _wrapped_view
  142.                     response = view_func(request, *args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\views\decorators\cache.py" in _wrapped_view_func
  44.         response = view_func(request, *args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\contrib\admin\sites.py" in inner
  223.             return view(request, *args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\contrib\admin\options.py" in add_view
  1637.         return self.changeform_view(request, None, form_url, extra_context)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\utils\decorators.py" in _wrapper
  45.         return bound_method(*args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\utils\decorators.py" in _wrapped_view
  142.                     response = view_func(request, *args, **kwargs)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\contrib\admin\options.py" in changeform_view
  1525.             return self._changeform_view(request, object_id, form_url, extra_context)

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\transaction.py" in __exit__
  212.                         connection.commit()

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\backends\base\base.py" in commit
  261.         self._commit()

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\backends\base\base.py" in _commit
  239.                 return self.connection.commit()

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\utils.py" in __exit__
  89.                 raise dj_exc_value.with_traceback(traceback) from exc_value

File "C:\Users\jack_\.virtualenvs\SNDProject-v81rGQ8f\lib\site-packages\django\db\backends\base\base.py" in _commit
  239.                 return self.connection.commit()

Exception Type: IntegrityError at /admin/auth_pp/posts/add/
Exception Value: FOREIGN KEY constraint failed

错误页面: /image/0pyRq.png

#CustomUserModel
class Usr(AbstractBaseUser):
    username = models.CharField(max_length=30, validators=[
    RegexValidator(
            regex=USERNAME_REGEX,
            message='Username must be alphanumeric or numbers',
            code='invalid_username'
        )
    ], unique=True)

    objects = UsrManager()

    is_active = models.BooleanField(default=True)
    is_admin = models.BooleanField(default=False)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)


    def has_perm(self, perm, obj=None):
    # Simplest possible answer: Yes, always
    return True

    def has_module_perms(self, app_label):  
    # Simplest possible answer: Yes, always
    return True

    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = []

#Model with ForeignKey 
class Posts(models.Model):
    title = models.CharField(max_length=50, unique=True)
    text = models.CharField(max_length=300)
    author = models.OneToOneField(get_user_model() ... default=1, swappable=True, related_query_name='post', db_constraint=True,      related_name='posts', on_delete=models.CASCADE)

对于代码中可能存在的缺陷和语法错误,我提前表示歉意。预先感谢您!

编辑: 错误仅发生在管理中,在 shell 中它有效

最佳答案

OneToOneField 表示一个用户只有一个帖子,一个帖子只有一个用户 这增加了唯一约束。 您需要使用外键(是的,您没有使用它)

author = models.ForeignKey(...)

关于python - Django 2.1.7,完整性错误,外键约束失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55248591/

相关文章:

python - Raspberry Pi 上的 PyQt5 Python 线程 RFID

python - 按照第一个 Django 应用程序教程,我无法执行 runserver 命令

python - django 1.4 如何从客户端自动获取用户的时区

django - 获取两个模型之间的 related_name

python-3.x - 如何使用 pyInstaller 将所有必需的库完全打包?

python - numpy数组迭代的优化

python - 特拉维斯建立。导入错误 : No module named gdal

python-3.x - Seaborn分类图的问题

python-3.x - 如何解码文件中base64格式的编码值?

python - Mypy 索引类型 "str"为 "Union[str, Dict[str, str]]"无效;预期类型 "Union[int, slice]"