我注意到我的 django 代码经常使用完全相同的查询调用我的数据库。
我知道当我实际需要数据显示在页面上或进行评估时,会产生 db hit。但是,我的模板代码如下所示:
模板:
{% if item.listing %}
{{ item.name }} text <strong>{{ item.listing|lowestprice }}</strong> more text
{% else %}
{{ item.name }} even more text
{% endif %}
....
{% for listed_item in item.listing %}
....
{% endfor %}
自定义过滤器:
def lowestprice(value):
try:
val = unicode(value[0].price) + unicode(value[0].symbol)
return val
except:
return "not available"
此代码命中我的数据库三次。第一个在我的自定义过滤器上的模板{% if .. %}
第二个,第三个在{% for %}
循环上。
列表是我的模型类的一种方法,它返回一个带有一些非常昂贵的连接的原始 SQL 查询集。
def listing(self):
return Universe.objects.raw("ONE HELL OF A QUERY")
我怎样才能减少我的代码只命中数据库一次?
编辑:使用with
作品,但是否有可能避免自定义过滤器上的数据库命中?