Используйте инфраструктуру типов содержимого , предоставленную Django:
from django.db import models
from django.contrib.contenttypes.models import ContentType
from django.contrib.contenttypes import generic
class Other(models.Model):
content_type = models.ForeignKey(ContentType)
object_id = models.PositiveIntegerField()
content_object = generic.GenericForeignKey('content_type', 'object_id')
Затем вы можете создать некоторые из своих основных объектов:
>>> from myapp.models import object_a, object_b, Other
>>> a = object_a()
>>> a.foo = 'test'
>>> a.bar = 'value'
>>> a.save()
>>> b = object_b()
>>> b.foop = 'random'
>>> b.barp = 'values'
>>> b.save()
И затем сохранить ссылки наих в Other
объектах:
>>> o1 = Other()
>>> o1.content_object = a
>>> o1.save()
>>> o2 = Other()
>>> o2.content_object = b
>>> o2.save()
Теперь, если мы запросим все Other
объекты и проверим их:
>>> all = Other.objects.all()
>>> all[0].content_object
<object_a: object_a object>
>>> all[0].content_object.foo
u'test'
>>> all[1].content_object
<object_b: object_b object>
>>> all[1].content_object.foop
u'random'
Просматривая поля на Other
объект, мы можем видеть, как Django хранит общие отношения:
>>> all[0].content_type
<ContentType: object_a>
>>> all[0].object_id
1
Когда вы запускаете команду syncdb
для установки ваших моделей, Django создает уникальный объект ContentType
для каждой модели.Когда вы используете общие отношения, вы сохраняете внешний ключ к этой записи типа контента (определяющий, какой тип объекта находится на другом конце отношения), и уникальный идентификатор экземпляра модели.Поле generic.GenericForeignKey
не хранится в базе данных, но является оболочкой, которая принимает тип контента и идентификатор объекта и получает фактический объект для вас.