Django отношения "многие-к-одному" с 3 таблицами
Я не хочу никаких внешних ключей непосредственно в моей таблице пользователей, и по умолчанию, когда я добавляю поле внешнего ключа в мою пользовательскую модель User, Django генерирует 2 вкладки следующим образом:
Когда я добавляю поле "многие ко многим" в модель компании, я получаю 3 нужные таблицы, но при этом создается возможность для одного и того же пользователя быть в двух разных компаниях.
class Company(models.Model):
class Meta:
verbose_name = 'Company'
verbose_name_plural = 'Companys'
ordering = ['name']
db_table = 'companys'
id = models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, unique=True, verbose_name='ID Empresa')
name = models.CharField(max_length=100, verbose_name='Nome')
users = models.ManyToManyField(User, related_name='company', verbose_name='Users')
def __str__(self):
return self.name
Я хочу, чтобы Django генерировал дополнительную таблицу, содержащую только начальные ключи двух моделей, но сохранял бихевиор отношения "многие-к-одному" между двумя моделями. примерно так:
вы можете сделать третью таблицу, используя отдельную модель
class Company(models.Model):
class Meta:
verbose_name = 'Company'
verbose_name_plural = 'Companys'
ordering = ['name']
db_table = 'companys'
id = models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, unique=True, verbose_name='ID Empresa')
name = models.CharField(max_length=100, verbose_name='Nome')
def __str__(self):
return self.name
class UserCompanyRelationModel(models.Model):
class Meta:
db_table = 'usr_comp'
user = models.OneToOneField(User, on_delete=models.CASCADE)
company = models.ForeignKey(Company, on_delete=models.CASCADE)