违反了 UNIQUE KEY 约束 'UQ__accounts'。无法在对象 'dbo.accounts_ouser' 中插入重复键。重复键值为 ()
Violation of UNIQUE KEY constraint 'UQ__accounts'. Cannot insert duplicate key in object 'dbo.accounts_ouser'. The duplicate key value is ()
在我的 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 上通过身份验证就可以访问它。
有人知道为什么会这样吗?
该错误表明您有用户违反了唯一约束,并且唯一约束是 NULL 值或空字符串。具有唯一约束的两个字段是 username
和 email
.
通过评论,我们查了一下,唯一约束UQ__accounts__AB6E616413786680
实际应用到了email
字段。问题是电子邮件字段被放入一个空字符串值 ''
。干杯!
在我的 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 上通过身份验证就可以访问它。
有人知道为什么会这样吗?
该错误表明您有用户违反了唯一约束,并且唯一约束是 NULL 值或空字符串。具有唯一约束的两个字段是 username
和 email
.
通过评论,我们查了一下,唯一约束UQ__accounts__AB6E616413786680
实际应用到了email
字段。问题是电子邮件字段被放入一个空字符串值 ''
。干杯!