Создание моделей с использованием отношений внешних ключей

У меня есть модель пользователя, которая выглядит следующим образом

class User(AbstractUser):
    email = models.EmailField(verbose_name='E-mail', max_length=255, unique=True)
    first_name = models.CharField(verbose_name='First Name', max_length=255)
    last_name = models.CharField(verbose_name='Last Name', max_length=255)
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)
    is_teacher = models.BooleanField(default=False)
    is_student = models.BooleanField(default=False)
    username = None

    teacher = models.OneToOneField(Teacher, on_delete=models.CASCADE, related_name='teacher')
    student = models.OneToOneField(Student, on_delete=models.CASCADE, related_name='student')

    objects = UserManager()

    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = ['first_name', 'last_name']

    def get_full_name(self):
        return self.first_name + " " + self.last_name

    def get_short_name(self):
        return self.first_name

    def __str__(self):
        return self.email

Мой менеджер пользователей

class UserManager(BaseUserManager):

    def create_user(self, email, first_name, last_name, password=None, **extra_fields):
        if not email:
            raise ValueError("Users must have an email address")
        if not first_name:
            raise ValueError("Users must have a first name")
        if not last_name:
            raise ValueError("Users must have a last name")
        if not password:
            raise ValueError("Users must have a password")

        user = self.model(
            email=self.normalize_email(email),
        )
        user.first_name = first_name
        user.last_name = last_name
        user.set_password(password)
        user.is_staff = False
        user.is_superuser = False
        user.is_active = True

        user.teacher = Teacher.objects.create()
        user.student = Student.objects.create()

        user.save(using=self._db)
        return user

    def create_superuser(self, email, first_name, last_name, password=None, **extra_fields):
        if not email:
            raise ValueError("User must have an email")
        if not password:
            raise ValueError("User must have a password")
        if not first_name:
            raise ValueError("User must have a first name")
        if not last_name:
            raise ValueError("User must have a last name")

        user = self.create_user(email, first_name, last_name, password)
        user.first_name = first_name
        user.last_name = last_name
        user.set_password(password)
        user.is_superuser = True
        user.is_staff = True
        user.save(using=self._db)
        return user

В моделях teacher и student есть только заполнители. Учитель и ученик являются типами пользователей, и я хочу, чтобы пользователь мог быть и учителем, и учеником. Когда я создаю пользователя, как мне создать экземпляр модели учителя и ученика и связать внешний ключ с пользователем?

Я получаю эту ошибку, когда пытаюсь создать пользователя

django.db.utils.IntegrityError: NOT NULL constraint failed: users_user.student_id

и я думаю, что это может быть проблемой

Вернуться на верх