Redis学习笔记---字典类型

来源:互联网 发布:轴承型号大全软件 编辑:程序博客网 时间:2024/04/29 19:48

补充

  在上篇博客中在介绍字符串类型的时候漏掉了一个比较重要的内容,在这里简单补充下.

  • 位操作
    Redis提供了四个命令可以直接对二进制位进行操作.
GETBIT key offsetSETBIT key offset valueBITCOUNT key [start] [end]BITTOP operation destkey key [key ... ]

GETBIT : 获取字符串类型键指定位置的二进制位的值(0或1),如果要获取的二进制位的索引位置超过了二进制位的实际长度,则默认位值为0
SETBIT : 设置字符串类型键指定位置的二进制位的值,如果要设置的二进制位的索引位置超出了二进制位的实际长度,SETBIT命令会自动将中间的二进制位设置为0.
BITCOUNT : 获取值是1的二进制位的个数,也可以通过参数限制统计字节的范围
BITTOP :

哈希类型(散列类型)

  散列类型的键值也是一种字典结构,存储了字段和字段值的映射,字段值只能是字符串类型。一个散列类型的键可以之多有2321 个字段。
  注意: redis的所有数据类型都不支持数据类型嵌套。
  例如要存储文章ID为0001的博客,则键可以设置为blog:0001,博客的title,author,content等作为字段。

127.0.0.1:6379> hset blog:0001 author gucb(integer) 1127.0.0.1:6379> hget blog:0001 author"gucb"127.0.0.1:6379> hset blog:0001 title "redis install"(integer) 1127.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
0 0
原创粉丝点击