Django отношения "многие-к-одному" с 3 таблицами

Я не хочу никаких внешних ключей непосредственно в моей таблице пользователей, и по умолчанию, когда я добавляю поле внешнего ключа в мою пользовательскую модель User, Django генерирует 2 вкладки следующим образом:

enter image description here

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

enter image description here

вы можете сделать третью таблицу, используя отдельную модель

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)
Вернуться на верх