Redis中hash类型的操作命令(命令的语法、返回值、时间复杂度、注意事项、操作演示)

文章目录

字符串和哈希类型相比

假设有以下一种场景:现在要在 Redis 中存储一个用户的基本信息(id=1、name=zhangsan、age=17),下图表示使用字符串类型进行存储和使用哈希类型进行存储的区别:

注意:在 Redis 中,"键" 称为 key,"值" 称为 value,如果value 的类型是哈希类型,则 "键" 称为 field,"值" 称为 value

hset 命令

设置 hash 中指定 "键"(field) 的值

语法:hset key field value [field value......]

返回值:添加的 field-value 的个数

时间复杂度:O(k),因为插入时,可以插入多个,所以,k 表示插入的键值对(field-value) 的个数

操作演示:

hget 命令

获取 hash 中指定 "键"(field) 的值

语法:hget key field

返回值:指定键(field)的值

时间复杂度:O(1)

操作演示:

hexists

判断 hash 中是否存在指定的 field

语法:hexists key field

返回值:1 表示存在,0 表示不存在

时间复杂度:O(1)

操作演示:

hdel

删除 hash 中指定的键(field)

语法:hdel key filed [filed......]

返回值:成功删除field的个数

时间复杂度:O(k),k 表示删除的键值对(field-value) 的个数

操作演示:

hkeys

获取哈希中所有的 field

语法:hkeys key

返回值:所有的键(field)

时间复杂度:O(N)

操作演示:

注意:这个操作要慎重使用,因为,如果field非常多话,那么就可能会造成 Redis 服务器阻塞

hvals

获取哈希中所有键(field)的值

语法:hvals key

返回值:所有的字段的值

时间复杂度:O(N),N表示field个数

操作演示:

注意:这个操作要慎重使用,因为,如果field非常多话,那么就可能会造成 Redis 服务器阻塞

hgetall

获取 hash 中所有的字段(field)及其对应的值

语法:hgetall key

返回值:所有的字段及其值

时间复杂度:O(N)

操作演示:

注意:返回值是一个字段一个值相对着,同时呢,这也是个危险的操作,如果字段特别多的情况下,就可能使 Redis 阻塞

hmget

一次获取 hash 中多个字段(field)的值

语法:hmget key field [field......]

返回值:指定字段的值

时间复杂度:O(k),k为指定的字段的数量

操作演示:

hlen

获取哈希中字(field)段的个数

语法:hlen key

返回值:字段的个数

时间复杂度:O(1),这里的个数不需要遍历计算,在内部有一个变量存储了元素个数

操作演示:

hsetnx

在字段不存在的情况下,设置字段和值

语法:hsetnx key field value

返回值:0 表示设置失败,1 表示设置成功

时间复杂度:O(1)

操作演示:

hincrby

将 hash 中字段(field)对应的值添加指定的值

语法:hincrby key field num

返回值:返回添加成功后的值

时间复杂度:O(1)

操作演示:

hincrbyfloat

hincrby 的浮点数版本,如果 field 的值是浮点数,对浮点数进行加减时,使用该命令。

语法:hincrbyfloat key field num

返回值:返回添加成功后的值

时间复杂度:O(1)

操作演示:

相关推荐
JavaGuide5 小时前
字节二面:Redis 能做消息队列吗?怎么实现?
redis·后端
漫霂7 小时前
基于redis实现登录校验
redis·后端
程序员小崔日记8 小时前
一篇文章彻底搞懂 MySQL 和 Redis:原理、区别、项目用法全解析(建议收藏)
redis·mysql·项目实战
读书笔记8 小时前
CentOS 7 安装 redis-6.2.6.tar.gz 详细步骤(从源码编译到启动配置)
redis
焗猪扒饭20 小时前
redis stream用作消息队列极速入门
redis·后端·go
雨中飘荡的记忆3 天前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
曲幽3 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
知我Deja_Vu8 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
Charlie_lll8 天前
Redis脑裂问题处理——基于min-replicas-to-write配置
redis·后端