【Redis】Redis常用命令之Hash

1.hset:设置hash中指定的字段(field)的值(value)。

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

时间复杂度:插⼊⼀组field为O(1),插⼊N组field为O(N)。

返回值:添加的字段的个数。
2.hget:获取hash中指定字段的值

redis 复制代码
HGET key field

时间复杂度:O(1),返回值:字段对应的值或者nil。

3.hexists:判断hash中是否有指定的字段

redis 复制代码
HEXISTS key field

时间复杂度:O(1),返回值:1表示存在,0表示不存在。
4.hdel:删除hash中指定的字段。

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

时间复杂度:删除⼀个元素为O(1),删除N个元素为O(N)。

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

5.hkeys:获取hash中的所有字段。

redis 复制代码
HKEYS key

时间复杂度:O(N),N为field的个数,返回值:字段列表。
6.hvals:获取hash中的所有的值。

redis 复制代码
HVALS key

时间复杂度:O(N),N为field的个数。返回值:所有的值。
7.hgetall:获取hash中的所有字段以及对应的值。

redis 复制代码
HGETALL key

时间复杂度:O(N),N为field的个数,返回值:字段和对应的值。

8.hmget:⼀次获取hash中多个字段的值。

redis 复制代码
HMGET key field [field ...]

时间复杂度:只查询⼀个元素为O(1),查询多个元素为O(N),N为查询元素个数。返回值:字段对应的值或者nil。
9.获取hash中的所有字段的个数。

redis 复制代码
HLEN key

时间复杂度:O(1),返回值:字段个数。

10.hsetnx:在字段不存在的情况下,设置hash中的字段和值。

redis 复制代码
HSETNX key field value

时间复杂度:O(1),返回值:1表示设置成功,0表示失败。

11.hincrby:将hash中字段对应的数值添加指定的值。

redis 复制代码
HINCRBY key field increment
HINCRBYFLOAT key field increment   //hincrby的浮点数版本

时间复杂度:O(1),返回值:该字段变化之后的值。

注意:在使⽤hgetall时,如果哈希元素个数⽐较多,会存在阻塞Redis的可能。如果只需要获取部分field,可以使⽤hmget,如果⼀定要获取全部field,可以尝试使⽤hscan命令,该命令采⽤渐进式遍历哈希类型。

总结:

命令 解释 时间复杂度
hset key field value 设置field的值是value O(1)
hget key field 获取field的value值 O(1)
hdel key field [field...] 删除field O(n),n是field的个数
hlen key 计算field的个数 O(1)
hgetall key 获取所有的field-value O(n),n是field的个数
hmget field [field ...] 批量获取field的value O(n),n是field的个数
hmset field value [field value ...] 批量设置field-value O(n),n是field的个数
hexists key field 判断 field 是否存在 O(1)
hkeys key 获取所有的 field O(n),n是field的个数
hvals key 获取所有的 value O(n),n是field的个数
hsetnx key field value 设置值,但必须在 field 不存在时才能设置成功 O(1)
hincrby key field n 对应 field-value +n O(1)
hincrbyfloat key field n 对应 field-value +n O(1)
hstrlen key field 计算 value 的字符串⻓度 O(1)
相关推荐
NineData8 小时前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL9 小时前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king12 小时前
入门 java 和 数据库
java·数据库·后端
jiayou6415 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData1 天前
NineData 迁移评估功能正式上线
数据库·dba
雨中飘荡的记忆1 天前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石2 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
曲幽2 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio