Redis中的hash数据类型

hash数据类型的操作命令:

1.HSET key field value

用来设置键值对

返回值是,设置成功的field-value的个数

这里设置了4个field-value。所以返回4

2.HGET key field

这个操作可以查对应field中的value。但是一次只能查一个

如果不存在则返回nil

3.HEXISTS key field

用来查看该field是否存在

存在就返回1,不存在就返回0。

4HDEL:

用来删除hash中指定的字段

注意:del删除的是key,hdel删除的是key。

这里返回0,是因为该key中不存在f1。

5HKEYS key

这个指令用来查看key中所有的field。

这个操作,先根据key找到对应的hash,时间复杂度O(1),然后遍历hash

注意:这个操作是有风险的

5.HVALS key:

这个指令和hkeys相对,能够获取到hash中所有的value。

6.HGETALL key:

该指令可以查出对应的key的所有field-value这个键值对。

这个操作的风险还是比较大。谨慎使用。

7.HMGET key field

可以一次查出多个field的value

多个value和查询时的field的顺序一致

hash的编码格式:

hash编码有hashtable,ziplist。

ziplist的内部数据结构也是精心设计的,目的是为了节省空间,用于小数据量储存,读写元素时,速度是比较慢的,元素个数多,这种慢就更加明显

1.哈希中的元素个数较少时,使用ziplist表示,元素个数比较多时,使用hashtable来表示

2.每个value比较短时,使用ziplist表示,如果某个value的长度太大,就会转换hashtable

配置:

hash-max-ziplist-entries配置 (默认512个)hash中的元素个数

hash-max-ziplist-value配置 (默认64字节)每个value的长度

hash的使用场景:

作为缓存:

string可以作为缓存使用,hash也可以,用来储存结构化的数据,使用hash类型更合适一些。

上述场景使用string类型也是可以做到的,就是需要使用json这样的数据格式。

但是如果使用string(json)格式来表示的UserInfo,我们只想修改其中的一个field,那么就需要把整个json都读出来转化成UserInfo对象,然后修改了对应的field,再转化成json并储存到Redis中,有点繁琐。

但是用hash的方式来表示UserInfo,此时就可以使用field表示的对象的每个属性,就可以很方便的修改任何一个属性的值了。

hash的方式需要更多的空间的代价,需要控制hash内的ziplist和hashtable两种内部编码格式的相互转化,可能造成内存的较大消耗。

相关推荐
TDengine (老段)43 分钟前
连接 TDengine 遇到报错 “failed to connect to server, reason: Connection refused” 怎么办?
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
李慕婉学姐2 小时前
Springboot黄河文化科普网站5q37v(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
Cabbage_acmer2 小时前
MySQL期中考试突击!
数据库·mysql
Lu Yao_2 小时前
Redis 缓存
数据库·redis·缓存
小桥流水人家哇3 小时前
性能测试单场景测试时,是设置并发读多个文件,还是设置不同的用户读不同的文件?
数据库·性能测试技巧
表示这么伤脑筋的题我不会3 小时前
Oracle 21C 部署ogg踩过的坑
数据库·oracle
你不是我我3 小时前
【Java 开发日记】MySQL 与 Redis 如何保证双写一致性?
数据库·redis·缓存
望获linux3 小时前
【实时Linux实战系列】实时 Linux 在边缘计算网关中的应用
java·linux·服务器·前端·数据库·操作系统
fredinators3 小时前
数据库专家
大数据·数据库
fredinators4 小时前
数据库flask访问
数据库·oracle·flask