【问题标题】:Violation of UNIQUE KEY constraint 'UQ__accounts'. Cannot insert duplicate key in object 'dbo.accounts_ouser'. The duplicate key value is ()违反 UNIQUE KEY 约束“UQ__accounts”。无法在对象“dbo.accounts_user”中插入重复键。重复键值为 ()
【发布时间】:2019-11-07 16:14:52
【问题描述】:

在我的 Django 站点中,我创建了一个自定义用户模型。我正在使用 Windows 身份验证,所以到目前为止,用户能够直接访问我的站点。我还可以在管理页面中创建用户并在那里编辑他们的权限。似乎突然间我收到错误Violation of UNIQUE KEY constraint 'UQ__accounts__AB6E616413786680'. Cannot insert duplicate key in object 'dbo.accounts_ouser'. The duplicate key value is (). 错误似乎是在数据库端,因为即使使用服务器管理工​​作室,我什至无法插入新用户。

class OUser(AbstractBaseUser, PermissionsMixin):
    email = models.EmailField(verbose_name='email address', max_length=255, unique=True)
    username = models.CharField(max_length=150, unique=True)
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)  # a superuser

    first_name = models.CharField(max_length=100, blank=True, default='')
    last_name = models.CharField(max_length=100, blank=True, default='')
    date_joined = models.DateField(auto_now=True)
    password = models.CharField(max_length=100)

    REQUIRED_FIELDS = []  # Email & Password are required by default.
    USERNAME_FIELD = 'username'

    def __str__(self):
        return self.username

    def has_perm(self, perm, obj=None):
        "Does the user have a specific permission?"
        # Simplest possible answer: Yes, always
        return True

    def has_module_perms(self, app_label):
        "Does the user have permissions to view the app `app_label`?"
        # Simplest possible answer: Yes, always
        return True

另一个奇怪的事情是使用 UNIQUE KEY 约束,因为列 id 应该是 PRIMARY KEY 约束,而用户模型没有实现任何其他键。 (我不确定这是否常见,但对我来说似乎很奇怪)

我希望网站回到原来的状态,如果用户在 Windows 上通过身份验证,他们就可以访问它。

有人知道为什么会这样吗?

【问题讨论】:

  • 更新:如果我删除一个用户,我可以添加另一个用户,但我可以在数据库中拥有的数量似乎是有限的。如果表中有5个,我可以插入,但是如果数据库中有6个,就会抛出op中列出的错误
  • 该错误似乎表明您的用户以某种方式违反了唯一约束,并且可能唯一约束是 NULL 值。 IIRC,Microsoft 违反 ANSI-SQL 并允许 NULL 计为唯一约束中的值。你能检查你的数据库用户名和电子邮件地址,看看你是否有一些是NULL 或包含一个空字符串?如果您查看数据库,约束UQ__accounts__AB6E616413786680 是否适用于username 字段或email 字段?
  • 感谢您的回复!错误如你所说,但不是空字符串。该字段用于电子邮件列。将您的评论复制到答案中,我会接受!

标签: sql-server django-models django-users django-pyodbc


【解决方案1】:

该错误表明您的用户违反了唯一约束,并且唯一约束是 NULL 值或空字符串。具有唯一约束的两个字段是usernameemail

通过 cmets,我们检查了,唯一约束 UQ__accounts__AB6E616413786680 实际应用于 email 字段。问题是电子邮件字段被放入空字符串值''。干杯!

【讨论】:

    猜你喜欢
    • 2012-03-05
    • 1970-01-01
    • 1970-01-01
    • 2013-05-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-06-30
    相关资源
    最近更新 更多