Redis 基础教程

Redis 命令

Redis 高级教程

Redis 笔记

Redis BITOP 命令

Redis 字符串(Strings)底层数据结构及所有相关命令 Redis 字符串(Strings)底层数据结构及所有相关命令


Redis BITOP 命令对一个或多个保存二进制位的字符串 key 进行位操作,并将结果保存到 destkey 上。

命令格式

BITOP operation destkey key [key ...]

可用版本:>=2.6.0

时间复杂度:O(N)

BITOP 操作支持 4 种位运算操作,AND、OR、XOR 和 NOT,具体形式如下:

  • BITOP AND destkey srckey1 srckey2 srckey3 ... srckeyN
  • BITOP OR destkey srckey1 srckey2 srckey3 ... srckeyN
  • BITOP XOR destkey srckey1 srckey2 srckey3 ... srckeyN
  • BITOP NOT destkey srckey

注释:除了 NOT(取反)操作之外,其他操作都可以接受一个或多个 key 作为输入。

处理不同长度的字符串

当 BITOP 处理不同长度的字符串时,较短的那个字符串所缺少的部分会被看作 0。

空的 key 也被看作是包含 0 的字符串序列。

返回值

保存到 destkey 的字符串的长度,和输入 key 中最长的字符串长度相等。

BITOP 的时间复杂度为 O(N),当处理大型矩阵(matrix)或者进行大数据量的统计时,最好将任务指派到从节点(slave)进行,避免阻塞主节点。

应用场景

使用 bitop 实现用户上线次数统计。BITOP 是对 BITCOUNT 命令一个很好的补充。不同的 bitmaps 进行组合操作可以获得目标 bitmap 以进行用户操作相关统计。

性能

BITOP 在长字符串处理相对缓慢,因为它的时间复杂度为 O(N);对于实时性高的需求,涉及长字符串的处理一个很好的方法是使用 bit-wise 操作以避免阻塞主实例。

示例

redis> SET key1 foobar
OK
redis> SET key2 abcdef
OK
redis> BITOP AND dest key1 key2
(integer) 6
redis> GET dest
"`bc`ab"