1,892   Redis

一,原理介绍:

1,简介:
Redis的hash数据类型类似map,是多个field和value的集合。

2,特点:
适合保存对象数据,相较于将对象的每个字段存成单个string类型。将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象。

3,原理:
省内存的原因是新建一个hash对象时开始是用zipmap(又称为small hash)来存储的。
这个zipmap其实并不是hash table,但是zipmap相比正常的hash实现可以节省不少hash本身需要的一些元数据存储开销。
尽管zipmap的添加,删除,查找都是O(n),但是由于一般对象的field数量都不太多。
所以使用zipmap也是很快的,也就是说添加删除平均还是O(1)。

4,设置:
如果field或者value的大小超出一定限制后,redis会在内部自动将zipmap替换成正常的hash实现.
这个限制可以在配置文件中指定

hash-max-zipmap-entries 64 #配置field最多64个
hash-max-zipmap-value 512 #配置value最大为512字节

 

二,基本语法:

127.0.0.1:6379> hset user:100 name hello
(integer) 1
127.0.0.1:6379> hset user:100 age 20
(integer) 1
127.0.0.1:6379> hset user:100 sex m
(integer) 1
127.0.0.1:6379> hget user:100 name
"hello"
127.0.0.1:6379> hgetall user:100
1) "name"
2) "hello"
3) "age"
4) "20"
5) "sex"
6) "m"
127.0.0.1:6379> hmget user:100 name age sex
1) "hello"
2) "20"
3) "m"
127.0.0.1:6379> 




Leave a Reply

Your email address will not be published. Required fields are marked *