补充
在上篇博客中在介绍字符串类型的时候漏掉了一个比较重要的内容,在这里简单补充下.
- 位操作
Redis提供了四个命令可以直接对二进制位进行操作.
GETBIT key offset
SETBIT key offset value
BITCOUNT key [start] [end]
BITTOP operation destkey key [key ... ]
GETBIT : 获取字符串类型键指定位置的二进制位的值(0或1),如果要获取的二进制位的索引位置超过了二进制位的实际长度,则默认位值为0
SETBIT : 设置字符串类型键指定位置的二进制位的值,如果要设置的二进制位的索引位置超出了二进制位的实际长度,SETBIT命令会自动将中间的二进制位设置为0.
BITCOUNT : 获取值是1的二进制位的个数,也可以通过参数限制统计字节的范围
BITTOP :
哈希类型(散列类型)
散列类型的键值也是一种字典结构,存储了字段和字段值的映射,字段值只能是字符串类型。一个散列类型的键可以之多有
232−1
个字段。
注意: redis的所有数据类型都不支持数据类型嵌套。
例如要存储文章ID为0001的博客,则键可以设置为blog:0001,博客的title,author,content等作为字段。
127.0.0.1:6379> hset blog:0001 author gucb
(integer) 1
127.0.0.1:6379> hget blog:0001 author
"gucb"
127.0.0.1:6379> hset blog:0001 title "redis install"
(integer) 1
127.0.0.1:6379> hget blog:0001 title
"redis install"
接下来详细介绍散列类型的各命令的使用方法,同样先通过帮助命令查看下哈希类型大体有哪些命令。
127.0.0.1:6379>help @hash
命令原型 | 时间复杂度 | 命令描述 | 返回值 |
---|---|---|---|
HDEL key field [field …] | o(n) | 时间复杂度中的n为待删除字段的数量,如果待删除的字段不存在则忽略,如果待删除的键不存在,则视为空,返回值为0 | 实际删除的字段数 |
HEXISTS key field | o(1) | 判断指定键的指定的字段否存在 | 如果存在返回1,如果键或字段不存返回0 |
HGET key field | o(1) | 获取键中指定字段的关联值 | 如果存在返回其关联值,如果键或字段不存在返回nil |
HGETALL key | o(n) | 获取键key中所有字段的值,n为键key中包含的字段的数量 | 返回字段-值的列表 |
HINCRBY key field increment | o(1) | 增加指定Key中指定Field关联的Value的值。如果Key或Field不存在,该命令将会创建一个新Key或新Field,并将其关联的Value初始化为0,之后再指定数字增加的操作。该命令支持的数字是64位有符号整型,即increment可以负数 | 返回增加后的值 |
HINCRBYFLOAT key field increment | o(1) | 同上,只是增量值为浮点数 | 返回增加后的值 |
HKEYS key | o(n) | 时间复杂度中的n表示Key包含的Field数量。返回指定Key的所有Fields名 | 返回字段列表 |
HLEN key | o(1) | 获取键key包含字段的数量 | 返回字段数量 |
HMGET key field [field …] | o(n) | 时间复杂度n为要获取的字段数,返回指定key的field关联的值,如果key不存在返回一组nil | 返回field关联的值 |
HMSET key field value [field value …] | o(n) | 时间复杂度n为要设置的字段数n,依次对键key的各个field设置值,如果field已存在则覆盖原先的值,如果不存在则新建 | |
HSCAN key cursor [MATCH pattern] [COUNT count] | 2 | 3 | 4 |
HSET key field value | 2 | 3 | 4 |
HSETNX key field value | 2 | 3 | 4 |
HVALS key | 2 | 3 | 4 |