Redis hashes类型及操作

hashes类型及操作

Redis hash是一个string类型的field和value的映射表。他的添加、删除操作都是O(1)(平均)。
hash特别适合用于存储对象。相较于将对象的每个字段存成单个string类型。将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象。省内存的原因是新建一个hash对象时开始是用zipmap(又称为small hash)来存储的。这个zipmap其实并不是hashtable,但是zipmap相比正常的hash实现可以节省不少hash本身需要的一些元数据存储开销。尽管zipmap的添加,删除。查找都是O(n),但是由于一般对象field数量都不太多。所以使用zipmap也是很快的,也就是说添加删除平均还是O(1)。如果field或者value的大小超过一定限制后,Redis会在内部自动将zipmap替换成正常的hash实现。这个限制可以在配置文件中指定。
hash-max-zipmap-entries 64 #配置字段最多64个
hash-max-zipmap-value 512 #配置value最大为512字节.

1.hset 设置hash field为指定值,如果key不存在,则先创建。

hset myhash key1 value1

2.hsetnx 设置hashfield为指定值,如果key不存在,则先创建。如果field已经存在,返回0,nx是not exist的意思。

hsetnx myhash key1 value
integer 0

3.hmset 同时设置多个field

hmset myhash key1 value1 key2 value2

4.hget 获取指定的hash field

hget myhash key1

5.hmget 获取多个指定的hash field

hmget myhash field1 field2 field3

6.hincrby 指定的hash field加上给定值

hincrby myhash age -8

7.hexists 测试指定field是否存在

hexists myhash key1

8.hlen返回指定hash的field数量

hlen myhash

9.hdel 删除某个myhash中指定field 返回指定的myhash数量

hdel myhash field1

10.hkeys 返回hash的所有field

hkeys myhash

11.hvals 返回hash的所有value

hvals myhash

12.hgetall 获取某个hash中全部的field及value

hgetall myhash

总结:对于hash类型的操作,和对string类型的操作类似,就我的使用而言,使用hash的数据结构,存储起来的结构更加明了。性能方面,由于没有看底层的数据结构,就暂时不去评价。

本文链接:

https://heyzen.club/index.php/Coder/82.html
1 + 9 =
快来做第一个评论的人吧~