Нарушение ограничения UNIQUE KEY 'UQ__accounts'. Невозможно вставить дубликат ключа в объект «dbo.accounts_ouser». Дубликат значения ключа () - PullRequest
0 голосов
/ 07 ноября 2019

На моем сайте 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, поскольку идентификатор столбца должен быть ограничением PRIMARY KEY, а модель пользователя не реализует никаких других ключей. (Я не уверен, распространено ли это или нет, но мне это кажется странным)

Я хотел бы, чтобы сайт вернулся к тому, как он был, где пользователь мог бы посетить его, если бы он былАутентифицирован на Windows.

Кто-нибудь есть идеи, почему это может быть?

1 Ответ

1 голос
/ 08 ноября 2019

Ошибка указывает, что у вас есть пользователи, нарушающие уникальное ограничение, и что уникальное ограничение является значением NULL или пустой строкой. Два поля с уникальным ограничением: username и email.

. С помощью комментариев мы проверили, и уникальное ограничение UQ__accounts__AB6E616413786680 фактически применено к полю email. Проблема заключалась в том, что поля электронной почты вставлялись с пустым строковым значением, ''. Ура!

...