Django:如何缓存函数

2024-04-19 19:16:06 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个在后端运行python的web应用程序。当我的页面加载时,会调用一个django函数,该函数运行一个SQL查询,该查询大约需要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关于缓存的文档,但它展示了如何缓存整个页面,而不是一个特定的函数。如果你能提供一个简单的例子或者一个教程的链接,那就太好了。谢谢:)


Tags: django方法函数用户web应用程序sql情况
1条回答
网友
1楼 · 发布于 2024-04-19 19:16:06

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

from django.views.decorators.cache import cache_page

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

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

^{pr2}$

相关问题 更多 >