Django Как связать внешний ключ со многими таблицами

У меня есть n классов, и каждый класс содержит столбец key вот так (где n==3)

class class1(models.Model):
    Id1 = models.AutoField(primary_key=True)
    key = models.CharField(max_length = 16, blank=True)

class class2(models.Model):
    Id2 = models.AutoField(primary_key=True)
    key = models.CharField(max_length = 16, blank=True)

class class3(models.Model):
    Id3 = models.AutoField(primary_key=True)
    key = models.CharField(max_length = 16, blank=True)

Я хочу сделать столбец key в качестве внешнего ключа между всеми n классами? Я знаю, как сделать внешний ключ между двумя классами, но я хочу сделать это с большим количеством классов, потому что у меня около 40 классов и некоторые классы имеют несколько коммутируемых столбцов

Вы можете использовать генеративные отношения для создания внешнего ключа к генеральной модели. Вам нужно использовать фреймворк ContentType, пишите свои модели так:

from django.contrib.contenttypes.fields import GenericForeignKey
from django.contrib.contenttypes.models import ContentType
from django.db import models

class class1(models.Model):
    Id1 = models.AutoField(primary_key=True)
    content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
    object_id = models.PositiveIntegerField()
    content_object = GenericForeignKey('content_type', 'object_id')

class class2(models.Model):
    Id2 = models.AutoField(primary_key=True)
    content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
    object_id = models.PositiveIntegerField()
    content_object = GenericForeignKey('content_type', 'object_id')

Тогда при создании экземпляра class1 вы можете сделать внешний ключ к экземпляру class2 (или другой модели) с помощью:

class1_instance = class1.objects.create(content_object=class2.objects.get(id2=1))

Затем вы можете получить доступ к экземпляру class2 с помощью:

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