Django:如何缓存一个函数

Par*_*ala 3 python django caching

我有一个在后端运行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")
Run Code Online (Sandbox Code Playgroud)

我似乎无法找到如何做到这一点的例子.我查看了Django关于缓存的文档,但它显示了如何缓存整个页面而不是特定的功能.如果您可以提供一个简单的示例或指向教程的链接,那将是很棒的.谢谢 :)

Mos*_*oye 7

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

from django.views.decorators.cache import cache_page

@cache_page(600) # 10 minutes
def populateDropdown(request):
    ...
Run Code Online (Sandbox Code Playgroud)

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

from django.core.cache import cache

def populateDropdown(request):
    if not cache.get('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 = list(cur)
        dropList = simplejson.dumps({"dropList": dropList})
        cache.set('droplist', dropList, 600) # 10 minutes
    return HttpResponse(cache.get('droplist'), content_type="application/json")
Run Code Online (Sandbox Code Playgroud)