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

相关推荐
好奇的菜鸟5 分钟前
Ubuntu 18.04 启用root账户图形界面登录指南
数据库·ubuntu·postgresql
天桥下的卖艺者6 分钟前
使用R语言编写一个生成金字塔图形的函数
开发语言·数据库·r语言
Facechat18 分钟前
鸿蒙开发入坑篇(九):本地数据库 (RDB) 深度解析
数据库·华为·harmonyos
Dxy123931021619 分钟前
MySQL删除表语句详解
数据库·mysql
编程彩机23 分钟前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
uoKent28 分钟前
MySQL常见命令梳理大纲
数据库·mysql
Moshow郑锴32 分钟前
Spring Boot Data API 与 Redis 集成:KPI/图表/表格查询的缓存优化方案
spring boot·redis·缓存
晚霞的不甘40 分钟前
Flutter for OpenHarmony专注与习惯的完美融合: 打造你的高效生活助手
前端·数据库·经验分享·flutter·前端框架·生活
2301_7657031442 分钟前
工具、测试与部署
jvm·数据库·python
山岚的运维笔记1 小时前
SQL Server笔记 -- 第13章:IF...ELSE
数据库·笔记·sql·microsoft·sqlserver