Redis类型之Hash

1.hash常用操作

这里还是要强调,redis的类型指的是value的类型。故而这里的hash是把key这一层组织完成以后,到了value这一层,value的其中一种类型还可以是hash。

1.1 HSET 和 HGET

HSET:设置hash类型的key

cpp 复制代码
HSET key field value [field value ...]

返回值是设置成功的键值对(field-value)的个数

HGET:获取对应key中对应field的值

cpp 复制代码
HGET key field

返回值为查询key中对应的field对应的value,如果不存在则返回nil

1.2 HDEL

HDEL:删除hash中指定的字段

注意:del删除的key而hdel删除的field

cpp 复制代码
HDEL key field [field ...]

返回值为本次操作删除的字段个数

1.3 HKEYS

HKEYS:这个操作,先根据key找到对应的value(hash),然后再遍历value

cpp 复制代码
HKEYS key

返回值就是这个key中所有的field

我上面这个操作存在一定的风险,就类似于之前的keys * ,如果key中的hash存在大量的field就有可能让我们的redis阻塞住。

1.4 HVALS

HVALS:和hkeys相对能够获取到hash中的所有value

cpp 复制代码
HVALS key

返回值就是对应key中的所有field对应的值

1.5 HGETALL

HGETALL:查询value中的所有数据

cpp 复制代码
HGETALL key

返回值就是value中的所有数据包括field和value

其实上面这样的操作风险还是有亿点大的,多数情况下,不需要查询所有的field,可能只需要查其中的几个field

1.6 HLEN

HLEN:获取hash的元素个数,不需要遍历

cpp 复制代码
HLEN key

返回值就是hash的长度

1.7 HSETNX

HSETNX:类似于setnx。不存在的时候,才能设置成功,如果存在则失败。

cpp 复制代码
HSETNX key field value

1.8 常用操作小结

|---------------------------------------|-------------------------|-------|
| 命令 | 执行效果 | 时间复杂度 |
| hset key field value | 设置值 | O(1) |
| hget key field | 获取值 | O(1) |
| hdel key field [field ...] | 删除field | O(k) |
| hlen key | 计算field个数 | O(1) |
| hgetall key | 获取所有的field-value | O(k) |
| hmget field [field ...] | 批量获取field-value | O(k) |
| hmset field value [field value ...] | 批量设置field-value | O(k) |
| hexists key field | 判断field是否存在 | O(1) |
| hkeys key | 获取所有的field | O(k) |
| hvals key | 获取所有的value | O(k) |
| hsetnx key field value | 设置值,但必须再field不存在时才能设置成功 | O(1) |
| hincrbykey field n | 对应field-value + n | O(1) |
| hincrbyfloat key field n | 对应field-value + n | O(1) |
| hstrlen key field | 计算value的字符串长度 | O(1) |

2.redis中的hash的内部编码

rar、zip、gzip、7z...这些是具体的压缩算法

压缩的本质是针对数据进行重新编码。不同的数据,有不同的特点,结合这些特点,进行精妙的设计,重新编码之后,就能缩小体积。类似的例子如下

2.2 ziplist

ziplist存在的目的就是节省空间,ziplist内部的数据结构是精心设计的

使用hash来表示一个普通的hash表,可能会浪费一定的空间(hash首先是一个数组,数组上有些位置有元素,有些没有)

3.redis中的hash的应用

相关推荐
埃伊蟹黄面2 分钟前
字符串算法精要与例题汇编
c++·算法·leetcode·字符串
Roye_ack5 分钟前
【leetcode hot 100】刷题记录与总结笔记(4/100)
笔记·算法·leetcode
黑牛先生15 分钟前
【GDB】调试Jsoncpp源码
开发语言·c++·算法
大大大大物~32 分钟前
JVM 之 垃圾回收算法及其内部实现原理【垃圾回收的核心问题有哪些?分别怎么解决的?可达性分析解决了什么问题?回收算法有哪些?内部怎么实现的?】
jvm·算法
不夜牛仔40 分钟前
算法笔记19 - 图和通用结构 | 图的两种遍历 | 三种拓扑排序 | 两种最小生成树算法Kruskal, Prim | 最短路径算法Dijkstra
笔记·算法
小龙报43 分钟前
【算法通关指南:基础算法篇】高精度专题:一篇破除超数运算问题
c语言·数据结构·c++·算法·链表·贪心算法·visual studio
ULTRA??43 分钟前
Informed RRT*算法,并包含圆形障碍物环境
人工智能·python·算法
Yupureki44 分钟前
《算法竞赛从入门到国奖》算法基础:入门篇-双指针
c语言·开发语言·数据结构·c++·算法·visual studio
AshinGau44 分钟前
权重衰减(Weight Decay)
神经网络·算法
Liangwei Lin44 分钟前
洛谷 P3367 【模板】并查集
算法