{{{
class Metadata(models.Model):
name = models.CharField(max_length=255)
class Property(Metadata):
pass
class ObjectClass(Metadata):
pass
class DataElementConcept(Metadata):
object_class = models.ForeignKey(ObjectClass)
property= models.ForeignKey(Property)
}}}
However, the system checker has a problem with this:
{{{
SystemCheckError: System check identified some issues:
ERRORS:
aristotle_mdr.DataElementConcept.property: (models.E006) The field
'property' clashes with the field 'property' from model
'aristotle_mdr._concept'.
}}}
What appears to happen is that DataElementConcept.property (a relation
between two pieces of metadata) is clashing with MetadataItem.property (a
relation from parent class to child class).
Since a parent-child relationship using inheritance is just a
OneToOneField thats made by
[https://github.com/django/django/blob/5cc746206726c538c36a2830e7c068f1c8a0e7c8/django/db/models/base.py#L234
django.db.models.base.ModelBase] it'd be nice to be able to add some
details to a classes Meta field to change the related_name of the
generated field, for example:
{{{
class Metadata(models.Model):
name = models.CharField(max_length=255)
class Property(Metadata):
class Meta:
parent_related_name = "property_subclass"
}}}
and the ModelBase coude would be similar to:
{{{
field = OneToOneField(
base,
on_delete=CASCADE,
name=attr_name,
auto_created=True,
parent_link=True,
related_name=base._meta.parent_related_name
)
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/28563>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
Comment (by Simon Charette):
I'm not convinced it's worth adding a `Meta` option for the rare cases
when this is required. Explicitly defining your parent link as you've
pointed out should do.
{{{#!python
class Property(Metadata):
metadata_ptr = OneToOneField(
Metadata,
on_delete=CASCADE,
parent_link=True,
related_name='property_subclass',
)
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/28563#comment:1>
* owner: nobody => tothegump
* status: new => assigned
--
Ticket URL: <https://code.djangoproject.com/ticket/28563#comment:2>
* status: assigned => closed
* resolution: => wontfix
Comment:
Agreed, I think defining fields is a more clear solution than a `Meta`
option.
--
Ticket URL: <https://code.djangoproject.com/ticket/28563#comment:3>
Old description:
New description:
I didn't even realise that was possible! Cheers.
--
--
Ticket URL: <https://code.djangoproject.com/ticket/28563#comment:4>
Old description:
> I didn't even realise that was possible! Cheers.
New description:
{{{
class Property(Metadata):
pass
class ObjectClass(Metadata):
pass
}}}
{{{
}}}
--
Comment (by Samuel Spencer):
I didn't even realise that was possible! Cheers.
--
Ticket URL: <https://code.djangoproject.com/ticket/28563#comment:5>