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

相关推荐
workflower4 分钟前
软件工程-练习
数据库·需求分析·个人开发·极限编程·结对编程
扶尔魔ocy30 分钟前
【QT自定义2D控件】QGraphics绘制仪表盘
数据库·qt·microsoft
yookay zhang42 分钟前
达梦数据库监听进程
网络·数据库·oracle
Archy_Wang_144 分钟前
centos7的mysql做定时任务备份所有数据库
数据库·mysql
Java 码农1 小时前
MySQL基础操作案例设计
数据库·mysql
友友马2 小时前
『 QT 』按钮类控件属性解析
开发语言·数据库·qt
vvw&2 小时前
如何在 Ubuntu 上安装 PostgreSQL
linux·运维·服务器·数据库·ubuntu·postgresql
qq_5470261792 小时前
Canal实时同步MySQL数据到Elasticsearch
数据库·mysql·elasticsearch
java1234_小锋3 小时前
REDIS集群会有写操作丢失吗?为什么
数据库·redis·缓存
兰若姐姐3 小时前
如何进行MSSQL提权?sp_oacreate、sp_oamethod和沙盒提权以及xp_regwrighte提权
数据库·sqlserver