Redis 支持的数据结构包括 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs和 地理空间(geospatial) 索引半径查询。
本文主要针对其中散列(hashes)相关的命令进行讲解。
很多童鞋可能对hashes(哈希表)不是很了解,在这里我简单的介绍一下这种结构。
其实Java中的HashMap就是哈希表的一种实现,我们可以把哈希表想象成为一个容器,容器里面的内容是键值对(key-value)的形式,其中key是不允许重复的。
在Redis中我们把哈希表中的key称为filed,Redis中的一个key可以关联一个哈希表,如下图
Redis中哈希表相关的命令都是以H开头的
1. HET
作用: 将哈希表 key 中域 field 的值设置为 value 。
如果给定的哈希表并不存在, 那么一个新的哈希表将被创建并执行 HSET 操作。
如果域 field 已经存在于哈希表中, 那么它的旧值将被新值 value 覆盖
格式: HSET key field value
返回值:当 HSET 命令在哈希表中新创建 field 域并成功为它设置值时, 命令返回 1 ;如果域 field 已经存在于哈希表, 并且 HSET 命令成功使用新值覆盖了它的旧值, 那么命令返回 0 。
- 设置一个新域:
redis> HSET website google "www.g.cn"
(integer) 1
redis> HGET website google
"www.g.cn"
- 对一个已存在的域进行更新:
redis> HSET website google "www.google.com"
(integer) 0
redis> HGET website google
"www.google.com"
2. HSETNX
作用:
当且仅当域 field 尚未存在于哈希表的情况下, 将它的值设置为 value 。
如果给定域已经存在于哈希表当中, 那么命令将放弃执行设置操作。
如果哈希表 key 不存在, 那么一个新的哈希表将被创建并执行 HSETNX 命令。
格式: HSETNX key field value
返回值:HSETNX 命令在设置成功时返回 1 , 在给定域已经存在而放弃执行设置操作时返回 0 。
- 域尚未存在, 设置成功:
redis> HSETNX database key-value-store Redis
(integer) 1
redis> HGET database key-value-store
"Redis"
- 域已经存在, 设置未成功, 域原有的值未被改变:
redis> HSETNX database key-value-store Riak
(integer) 0
redis> HGET database key-value-store
"Redis"
3. HGET
作用:返回哈希表中给定域的值。
格式: HGET key field
返回值:
HGET 命令在默认情况下返回给定域的值。
如果给定域不存在于哈希表中, 又或者给定的哈希表并不存在, 那么命令返回 nil 。
- 域存在的情况:
redis> HSET homepage redis redis.com
(integer