1. 什么是散列

散列类似于一个字典,是一个<K, V>对的集合,不过这个key和value都只能是字符串类型的,不能嵌套,可以看做Java中的Map<String, String>。

 

2. 基本操作

赋值

散列操作不区分插入和更新,当设置一个field的时候如果不存在的话表示新增,如果已经存在的话则表示更新,之前的值会被覆盖掉。当设置值的时候如果field在之前不存在的话则返回1,视为新增,如果field已经存在的话,返回0,视为更新。

hset <key> <field> <value>

Redis数据类型之散列(hash)_其他

第一次赋值的时候因为k1不存在,是新增field操作,返回值是1,第二次k1已经存在了,是更新操作,返回值是0.

使用hmset一次赋多个值:

hmset <key> <field> <value> [<field> <value> …]

Redis数据类型之散列(hash)_其他_02

使用hsetnx只有当指定的field不存在时才赋值,这个是为了避免覆盖掉已有的值:

hsetnx <key> <field> <value>

Redis数据类型之散列(hash)_其他_03

返回值表示是否赋值成功,返回1表示这个field之前并不存在,此次赋值成功,返回0表示指定的field之前就已经存在,此次赋值失败。

 

取值

hget一次取一个值,hmget一次取出多个值:

hget <key> <field>
hmget <key> <field> [<field> …]

Redis数据类型之散列(hash)_其他_04

使用hgetall一次取出全部的field和value:

hgetall <key>

Redis数据类型之散列(hash)_其他_05 

用于获取hash表中的field集合和value集合:

hkeys <key>
hvals <key>

返回值是一个列表:

Redis数据类型之散列(hash)_其他_06 

总结一下:

hgetall 获取所有的field和value,组合成一个list返回
hkeys 获取所有的key集合,相当于java中的keySet()
hvals 获取所有的value集合,相当于java中的valueSet()

 

判断field是否已存在

hexists用于判断在指定的hash表中某个field是否已存在:

hexists <key> <field>

Redis数据类型之散列(hash)_其他_07

返回值是1或0,返回1表示指定的field已经存在,返回0表示不存在。

 

获取hash表中的field个数

使用hlen获取指定的hash表中field的个数:

hlen <key>

Redis数据类型之散列(hash)_其他_08

 

field自增

使用hincrby对某个整数类型的field一次自增某个整数量:

hincrby <key> <field> <increment>

Redis数据类型之散列(hash)_其他_09 

 

删除

要删除hash表中的某个field,使用hdel:

hdel <key> <field> [<field> …]

Redis数据类型之散列(hash)_其他_10

hdel的返回值是成功删除的field的个数。

可以一次删除多个filed:

Redis数据类型之散列(hash)_其他_11

返回值是2表示成功删除了两个field。

要删除hash表本身使用del命令:

Redis数据类型之散列(hash)_其他_12

del是用于删除key即hash表本身的,hdel是用于删除hash表中的field的。

 

 

参考资料:

1. 《redis入门指南》 第二版



Redis数据类型之散列(hash)_其他_13
本作品采用知识共享署名 4.0 国际许可协议进行许可。