繁体   English   中英

Django:如何缓存一个函数

[英]Django: how to cache a function

我有一个在后端运行 python 的 Web 应用程序。 当我的页面加载时,会调用一个运行 SQL 查询的 django 函数,该查询大约需要 15-20 秒才能运行并返回响应。 每次页面加载时都会发生这种情况,每次页面刷新时用户等待 15-20 秒会非常烦人。

所以我想知道是否有办法缓存来自查询的响应,并在页面第一次加载时将其存储在浏览器中的某个位置。 每当页面刷新后,我不会再次运行查询,而是从浏览器的缓存中获取数据,因此页面加载速度会更快。

这是页面加载时运行的函数

def populateDropdown(request):
    database = cx_Oracle.connect('username', 'password', 'host')
    cur = database.cursor()
    cur.execute("select distinct(item) from MY_TABLE")
    dropList = list(cur)
    dropList = simplejson.dumps({"dropList": dropList})
    return HttpResponse(dropList, content_type="application/json")

我似乎无法找到有关如何执行此操作的示例。 我查看了 Django 的缓存文档,但它显示了如何缓存整个页面而不是特定功能。 如果您能提供一个简单的示例或教程链接,那就太好了。 谢谢:)

您可以缓存运行该查询的视图的结果:

from django.views.decorators.cache import cache_page

@cache_page(600) # 10 minutes
def populateDropdown(request):
    ...

或者在视图中缓存昂贵的函数,在您的情况下几乎等同于缓存整个视图:

from django.core.cache import cache

def populateDropdown(request):
    dropList = cache.get('droplist')
    if not dropList: # check if droplist has expired in cache
        database = cx_Oracle.connect('username', 'password', 'host')
        cur = database.cursor()
        cur.execute("select distinct(item) from MY_TABLE")
        dropList = simplejson.dumps({"dropList": list(cur)})
        cache.set('droplist', dropList, 600) # 10 minutes
    return HttpResponse(dropList, content_type="application/json")

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM