0

我注意到我的 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作品,但是否有可能避免自定义过滤器上的数据库命中?

4

1 回答 1

2

您应该使用with一次昂贵的查询并将其存储在上下文中。

{% with item.listing as item_listing %}
   {% if item_listing %} ... {% endif %} ... etc ...
{% endwith %}
于 2012-07-28T22:24:07.397 回答