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;

redis zset转set 反序列化失败_Redis只往zset有序集合添加不存在的数据:关键字索引查询构建+源码分析...相关推荐

  1. redis zset转set 反序列化失败_关于Redis中的五种数据结构,要知其然知其所以然...

    Redis作为Nosql的代表,想必大家已经再熟悉不过了,除了作为缓存来使用,Redis还提供了其他很多有用的功能,例如可作为消息队列.分布式锁.不隆过滤器.限流等功能使用.今天先来说一说redis作 ...

  2. 升级SpringCloud到Hoxton.SR3后使用Fegin出现jackson反序列化失败,源码分析,原因lombok版本升级

    关键词 Caused by: com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Cannot construct insta ...

  3. Redis 数据结构-字典源码分析

    2019独角兽企业重金招聘Python工程师标准>>> 相关文章 Redis 初探-安装与使用 Redis 数据结构-字符串源码分析 本文将从以下几个方面介绍 前言 字典结构图 字典 ...

  4. Redis学习之intset整数集合源码分析

    1.整数集合:整数的集合,升序排序,无重复元素 2.整数集合intset是集合键的底层实现之一,当一个集合只包含整数值的元素,并且这个集合的元素数量不多时,redis会使用整数集合作为集合键的底层实现 ...

  5. 【作者面对面问答】包邮送《Redis 5设计与源码分析》5本

    墨墨导读:本文节选自<Redis 5设计与源码分析>,主要为读者分析Redis高性能内幕,重点从源码层次讲解了Redis事件模型,网络IO事件重在使用IO复用模型,时间事件重在限制最大执行 ...

  6. Redis 的 Sentinel哨兵介绍与源码分析(1):初始化部分

    http://www.redis.cn/topics/sentinel.html redis-6.0.8 本文是在官方中文文档的基础上进行的源码分析,其中包含完整的原文,并在此基础上,添加源码介绍. ...

  7. 新书推荐 |《Redis 5设计与源码分析》

    新书推荐 <Redis 5设计与源码分析> 点击上图了解及购买 好未来.滴滴.百度等公司专家联合撰写,掌握Redis 5设计与命令实现,透彻掌握分布式缓存. 编辑推荐 多名专家联袂推荐,资 ...

  8. redis源码分析 -- cs结构之服务器

    服务器与客户端是如何交互的 redis客户端向服务器发送命令请求,服务器接收到客户端发送的命令请求之后,读取解析命令,并执行命令,同时将命令执行结果返回给客户端. 客户端与服务器交互的代码流程如下图所 ...

  9. Redis分布式锁解析源码分析

    Redis分布式锁解析&源码分析 概述 实战 简单的分布式锁 Redisson实现分布式锁 Redission源码分析 构造方法 获取锁lock 解锁 锁失效 红锁 案例分析 原始的写法 进化 ...

最新文章

  1. 分类模型的评估方法-正确率(Accuracy)
  2. Android动态日志系统Holmes
  3. qt 字体不随dpi_Windows – QT5字体渲染在各种平台上不同
  4. android-开源项目_我如何摆脱对开源的恐惧,并开始了自己的项目-以及如何做到。...
  5. git报错:‘fatal:remote origin already exists‘怎么处理?附上git常用操作以及说明。
  6. 信息学奥赛一本通 2068:【例2.6】鸡兔同笼
  7. python提高文件读取速度_Python提高了HDF5文件的读取速度
  8. java代码使用Pair元组-运行可以-编译失败
  9. flutter: 根视图、根元素与根渲染
  10. xcode 制作静态库.a文件 详解
  11. 书单|互联网企业面试案头书之架构师篇
  12. arcview、arcinfo、arceditor的区别
  13. L298N 驱动模块的应用
  14. 蚂蚁金服的生死时速!
  15. 推荐10款适合C/C++开发人员的IDE
  16. 我室友拿到了美团50万年薪,太牛逼了
  17. 小孩子爱玩手机学计算机编程好吗,学习编程教育对孩子的哪些重要意义
  18. 移动宽带套餐介绍_移动宽带一年多少钱 2018移动宽带套餐介绍
  19. Modbus协议(翻自wiki)
  20. ABAP SY-系统值

热门文章

  1. 五子棋游戏设计VHDL语言
  2. 全国高等学校计算机等级考试(江西考区)一级笔试试卷a,全国高等学校计算机等级考试(江西考区)一级笔试试卷A...
  3. java 中数组与list_Java中List与数组相互转换实例分析
  4. 按照姓名升序排序的代码_干货:6种EXCEL排序方法,让老板对你刮目相看
  5. php伪静态url运用,再谈 THINKPHP 伪静态url(URL访问模式)的设置
  6. const int *p说明不能修改_C语言关键字const和指针结合的使用
  7. integer是值传递还是引用传递_值传递与引用传递
  8. Mybatis配置文件注释
  9. Mysql CURD复习(数据库、表、数据)
  10. poj 3411 1724