Создание моделей с использованием отношений внешних ключей
У меня есть модель пользователя, которая выглядит следующим образом
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
и я думаю, что это может быть проблемой