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