Below is a stripped down model and associated method. I am looking for a simple way upon executing a query to get all of the needed information in a single answer without having to re-query everything. The challenge here is the value is dependent upon the signedness of value_id.
class Property(models.Model):
property_definition = models.ForeignKey(PropertyDefinition)
owner = models.IntegerField()
value_id = models.IntegerField()
def get_value(self):
if self.value_id < 0: return PropertyLong.objects.get(id=-self.value_id)
else: return PropertyShort.objects.get(id=self.value_id)
Right now to get the “value” I need to do this:
object = Property.objects.get(property_definition__name="foo")
print object.get_value()
Can someone provide a cleaner way to solve this or is it “good” enough? Ideally I would like to simply just do this.
object = Property.objects.get(property_definition__name="foo")
object.value
Thanks
Given this is a bad design. You can use the builtin property decorator for your method to make it act as a property.
This would enable you to do what you’d ideally like to do:
Property.objects.get(pk=1).valueBut I would go as far as to call this “cleaner”. 😉
You could go further and write your own custom model field by extending
django.models.Fieldto hide the nastiness in your schema behind an API. This would at least give you the API you want now, so you can migrate the nastiness out later.That or the Generic Keys mentioned by others. Choose your poison…