OurJS


OurJS-我们的JS, 我们的技术-IT文摘; 专注JS相关领域;
我们热爱编程, 我们热爱技术;我们是高大上, 有品味的码农;

欢迎您订阅我们的技术周刊


我们会向您分享我们精心收集整理的,最新的行业资讯,技术动态,外文翻译,热点文章;
我们使用第三方邮件列表向您推送,我们不保存您的任何个人资料,注重您的隐私,您可以随时退订,

欢迎分享您的观点,经验,技巧,心得

让我们一起找寻程序员的快乐,探索技术, 发现IT人生的乐趣;


本网站使用缓存技术每次加载仅需很小流量, 可在手机中流畅浏览;
如果您发现任何BUG,请即时告知我们: ourjs(at)ourjs.com

Redis只往zset有序集合添加不存在的数据:关键字索引查询构建+源码分析


分享到


分类 心得体会   关键字 分享   发布 ourjs  1540738289407
注意 转载须保留原文链接,译文链接,作者译者等信息。  
Redis的有序集合Sorted Set(zset),可以很方便地用来构建关键字索引表,可以很方便地实现支持超大规模并发的关键字组合条件查询。

比如有套博客系统,博客文章存放在 hash 类型 article:* 中,其中的每个关键字对应的文章存放在 keyword:* 中,则可以用关键字连接查询 ZINTERSTORE 找到文章ID列表:

添加文章


方便起见,以node-redis添加hash为例:

client.hmset('article:001', { title: 'test1', content: '....', keywords: 'redis,技术' })
client.hmset('article:002', { title: 'test2', content: '..', keywords: 'redis' })
client.hmset('article:003', { title: 'test3', content: '....', keywords: 'redis,技术' })
client.hmset('article:004', { title: 'test4', content: '..', keywords: '技术' })

创建索引


zadd keyword:redis 1540736588833 001 1540736588833 002 1540736588833 003
zadd keyword:技术 1540736588833 001 1540736588833 003 1540736588833 004

1540736588833是权重值,是当前时间的毫秒值,代表什么时侯添加的这些关键字。

连接查询

ZINTERSTORE out 2 keyword:技术 keyword:redis

此时out中就会存放包含有技术和redis两个关键字的文章ID,即 001 和 003


只更新不存在的索引


有时侯,我们可能在构建索引时不影响原有索引的权重值,以此来保留每个关键字最初添加时的时间(权重分数)。以此来统计某个时间段添加此关键字的文章。

比如article:004添加了新的关键字redis,而且是和“技术”关键字一起提交的,此时会更新索引:

zadd keyword:技术  1550736588800 004
zadd keyword:redis 1550736588800 004

但是我们不希望 keyword:技术 的权重更新,因为此关键字已经存在了,则直接使用 NX 即可:

zadd keyword:技术   nx  1550736588800 004
zadd keyword:redis  nx  1550736588800 004

然后比如说现在想提取昨天之前添加的“技术“文章ID,则直接按score权重查询即可:

zrangebyscore keyword:技术 0  1550736588800

这在某些场景中非常有用,比如说销售给某些客户添加了“无意向客户“标签,后来在销售的努力下将其转化成了“潜在客户“,之后又转化成了“签单客户”,为了考核销售员业绩, 需要统计每周/每月的转化个数,可以用此种方法可计算某个时间段内添加该标签的客户ID。


还有一些其他的参数:

XX: 仅仅更新存在的成员,不添加新成员。
NX: 不更新存在的成员。只添加新成员。
CH: 修改返回值为发生变化的成员总数,原始是返回新添加成员的总数 (CH 是 changed 的意思)。更改的元素是新添加的成员,已经存在的成员更新分数。 所以在命令中指定的成员有相同的分数将不被计算在内。注:在通常情况下,ZADD返回值只计算新添加成员的数量。
INCR: 当ZADD指定这个选项时,成员的操作就等同ZINCRBY命令,对成员的分数进行递增操作。

同样可以使用XX来更新只存在的成员,可在一些特殊场景中使用。

分析 t_zset.c 的源码可知,这些参数是可以一起使用的,比如incr和XX/NX同时使用:

/* Parse options. At the end 'scoreidx' is set to the argument position
 * of the score of the first score-element pair. */
scoreidx = 2;
while(scoreidx < c->argc) {
    char *opt = c->argv[scoreidx]->ptr;
    if (!strcasecmp(opt,"nx")) flags |= ZADD_NX;
    else if (!strcasecmp(opt,"xx")) flags |= ZADD_XX;
    else if (!strcasecmp(opt,"ch")) flags |= ZADD_CH;
    else if (!strcasecmp(opt,"incr")) flags |= ZADD_INCR;
    else break;
    scoreidx++;
}
/* Turn options into simple to check vars. */
int incr = (flags & ZADD_INCR) != 0;
int nx = (flags & ZADD_NX) != 0;
int xx = (flags & ZADD_XX) != 0;
int ch = (flags & ZADD_CH) != 0;


社区评论 ( Beta版 )
OnceDoc 您自己的企业内容管理系统——文档、流程、知识库、报表、网盘All In One

访问404页面,寻找丢失儿童
 热门文章 - 分享最多
  1. Redis/Python被要求更改Master/Slave程序接口名称和描述
  2. 用JavaScript测试图像上两点之间的距离
  3. 用纯CSS改变html radio/checkbox默认背景颜色样式
  4. 用JavaScript实现basename获取路径中的文件名
  5. css去掉table的td单元格的间距cellspacing,设置隔行显示不同背景颜色
  6. redis5.x新特性,Stream流数据类型使用简单教程
  7. 用 OnceAir 搭建个人Git/Svn/照片备份服务器,每年电费7块钱

 相关阅读 - 心得体会
  1. redis5.x新特性,Stream流数据类型使用简单教程
  2. Debian/Ubuntu Linux搭建SVN服务器,并设置开机默认启动
  3. 怎样将Android手机中的照片和视频,通过APP自动同步备份到OnceAir云盘的共享目录中
  4. OnceAir自动考勤系统,无需手机签到打卡,轻松管理记录员工出勤信息
  5. 如何为OnceAir顽石个人私有云盘设置固定公网访问地址
  6. redis、memcache和mongodb各自的优缺点是什么,怎么选择呢?
  7. 命令行的艺术:linux bash命令大全详解
  8. 开源项目 RethinkDB 关闭,创始人总结失败教训
  9. JavaScript中该如何安排后台任务
  10. Markdown 语法简介和使用说明-详细版

 关键字 - 分享
  1. C语言用指针模拟按引用传递int整型参数
  2. IE、Chrome、Firefox浏览器默认首页被改成360导航解决办法(删除daohang88.com)跳转
  3. Redis只往zset有序集合添加不存在的数据:关键字索引查询构建+源码分析
  4. redis5.x新特性,Stream流数据类型使用简单教程
  5. 一位自由职业者的分享:程序员怎样找兼职?
  6. 对于现代开发来说,JavaScript就是一种垃圾语言
  7. 我为什么不再用Compass写CSS(缺点分析)
  8. Redis/Python被要求更改Master/Slave程序接口名称和描述
  9. 程序员疑似将MySQL用户名密码上传至Github,导致华柱1.3亿条开房数据泄漏
  10. 从 Node 到 Go:一个粗略的比较—GO平均性能比JavaScript快十几倍

 欢迎订阅 - 技术周刊

我们热爱编程, 我们热爱技术; 我们是高端, 大气, 上档次, 有品味, 时刻需要和国际接轨的码农; 欢迎您订阅我们的技术周刊; 您只需要在右上角输入您的邮箱即可; 我们注重您的隐私,您可以随时退订.
加入我们吧! 让我们一起找寻码农的快乐,探索技术, 发现IT人生的乐趣;


 关注我们

我们的微信公众号: ourjs-com
打开微信扫一扫即可关注我们:
IT文摘-程序员(码农)技术周刊

ourjs官方微信号