在前文中我们已经介绍了Redis中有关字符串的大部分命令。在本文中,我们将介绍一下Redis中位操作相关的命令,并简单介绍6.0版本中新增的STRALGO命令。若需要了解其他的字符串命令,可参考之前的文章:
SETBIT
SETBIT
命令用于设置指定偏移位的二进制值,设置的值必须为0
或1
。
SETBIT key offset value
使用SETBIT
命令时,偏移量的值必须大于等于0,且小于4294967296(2^32)。若偏移量大于原字符串的长度,则该字符串将增长至能存放偏移量的长度,增长的部分将使用0
填充。
示例
redis> SETBIT mykey 7 1
(integer) 0
redis> GET mykey
"\x01"
redis> SETBIT mykey 7 0
(integer) 1
redis> GET mykey
"\x00"
当偏移量大于字符串长度时,字符串将增长:
redis> SET greeting "hello world"
OK
redis> SETBIT greeting 94 1
(integer) 0
redis> GET greeting
"hello world\x02"
GETBIT
GETBIT
命令用于返回指定指定偏移量的二进制值。
GETBIT key offset
使用GETBIT
命令时若指定的偏移量大于字符串的长度,将认定超出的部分为连续的0。当键值对不存在时,将认定其为一个空白的字符串,即偏移量大于字符串的长度。与SETBIT
命令不同的是,偏移量超出字符串时不会使字符串增长。
示例
redis> SETBIT mykey 7 1
(integer) 0
redis> GETBIT mykey 7
(integer) 1
redis> SET greeting "hello world"
OK
# 字符h的二进制为01101000H
redis> GETBIT greeting 0
(integer) 0
redis> GETBIT greeting 1
(integer) 1
# greeting的长度为88位,获取超出字符串的长度的位
redis> GETBIT greeting 88
(integer) 0
BITCOUNT
BITCOUNT
命令用于获取指定范围内字符串中二进制值为1
的位数。默认情况下计数范围为整个字符串,另外也可手动指定计数开始和结束的位置。不同于上文中介绍的SETBIT
以及GETBIT
命令,BITCOUNT
参数中的偏移量单位为字节而非位。
BITCOUNT key [start end]
与前文中介绍过的