models.py:
class Ingredient(models.Model):
_est_param = None
param = models.ManyToManyField(Establishment, blank=True, null=True, related_name='+', through='IngredientParam')
def est_param(self, establishment):
if not self._est_param:
self._est_param, created = self.ingredientparam_set\
.get_or_create(establishment=establishment)
return self._est_param
class IngredientParam(models.Model):
#ingredient params
active = models.BooleanField(default=False)
ingredient = models.ForeignKey(Ingredient)
establishment = models.ForeignKey(Establishment)
のパラメータを使用してすべての材料を取得する必要がありEstablishment
ます。まず、のようなすべてのパラメータをフェッチIngredients.objects.all()
して使用しますIngredients.objects.all()[0].est_param(establishment).active
。django 1.4 prefetch_relatedを使用してSQLクエリを減らすにはどうすればよいですか?の個々のEstablishment
プロパティを保存するために他の方法を使用できるかもしれIngredient
ませんか?