python - Django:如何缓存一个函数

标签 python django caching

我有一个在后端运行 python 的网络应用程序。当我的页面加载时,会调用一个运行 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 关于缓存的文档,但它显示了如何缓存整个页面而不是特定功能。如果您能提供一个简单的示例或指向教程的链接,那就太好了。谢谢:)

最佳答案

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

from django.views.decorators.cache import cache_page

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

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

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")

关于python - Django:如何缓存一个函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38508240/

相关文章:

python - 如何在 pymongo 中使用 "group"对相似行进行分组?

python - ximgproc(opencv-contrib 子模块)安装成功,但我收到 AttributeError

linux - 如何将 "tar"shell 命令翻译成 Python

javascript - 更新内容时出错

node.js - 在nodejs服务器上的内存存储中

caching - 是否可以使用相同的 url 和不同的 cookie 值(语言)来改变页面缓存(具有缓存版本)?

python - 在 Python 中编辑文本文件中的特定行

python - Django + Scrapy 多爬虫架构

python - Django 查询过滤器中的参数 "name__icontains"和 "description__icontains"是什么意思?

javascript - 在 iOS 上的 Safari 中刷新图像