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两种内部编码格式的相互转化,可能造成内存的较大消耗。

相关推荐
樹JUMP8 小时前
Python虚拟环境(venv)完全指南:隔离项目依赖
jvm·数据库·python
用什么都重名8 小时前
Redis 入门与实践:从基础到 Stream 消息队列
数据库·redis·缓存
Mistra丶8 小时前
记一次 JVM+Postgresql的 “死锁” 问题排查
jvm·数据库·postgresql·死锁
一然明月8 小时前
Qt QML 锚定(Anchors)全解析
java·数据库·qt
苦瓜小生8 小时前
【黑马点评学习笔记 | 实战篇 】| 7-达人探店
redis·笔记·后端·学习
大树学长8 小时前
【QT开发】Redis通信相关(一)
redis·qt
分享牛8 小时前
Operaton入门到精通23-Operaton 2.0 原生支持 JUnit 6 核心指南
数据库·junit
编码忘我9 小时前
mysq系列之事务
数据库
知识分享小能手9 小时前
Redis入门学习教程,从入门到精通,Redis进阶编程知识点详解(5)
数据库·redis·学习
MekoLi299 小时前
MongoDB 新手完全指南:从入门到精通的实战手册
数据库·后端