首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用memcached每用户的查询

使用memcached每用户的查询
EN

Stack Overflow用户
提问于 2012-04-15 00:49:30
回答 1查看 227关注 0票数 0

我正在开发一个web应用程序,并试图了解memcached是如何工作的。

我的问题是如何使用memcached获得最佳结果。

在应用程序中,当每个用户登录时,sql查询将检查7-8个表,并以数组形式获得结果。我在考虑在memcached中缓存这些数组。但是它应该如何工作呢?

我应该在memcached中使用唯一键缓存每个用户的数组吗?

我应该如何刷新这些阵列?是不是干了什么活?

提前感谢你的点子。

EN

回答 1

Stack Overflow用户

发布于 2012-04-15 01:04:33

数据是否应该由具有唯一键的用户缓存取决于数据对于该用户是否是唯一的。应该如何刷新阵列取决于数据的更改方式。因此,一般来说,你的问题是无法回答的,在提出具体问题之前,你需要阅读一些教程。

假设您有一个输出仅依赖于传递的参数的函数,您可以根据这些参数创建一个键(例如,这是一个获取用户数据的函数,您正在传递$userId -您的键可以是userdata/$userId),您可以缓存该函数的返回值

代码语言:javascript
运行
复制
function get_user_data($userId) {
    $cacheKey = 'userdata/' . $userId;
    $result = cache::instance()->get($cacheKey);
    if ($result == false) {
       // body of the function
       cache::instance()->set($cacheKey, $result);
    }
    return $result;
}

至于失效,当一些数据被更改时,只需从memcache中删除键即可

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10155436

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档