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)

操作演示:

相关推荐
Dlwyz10 分钟前
redis-击穿、穿透、雪崩
数据库·redis·缓存
工业甲酰苯胺2 小时前
Redis性能优化的18招
数据库·redis·性能优化
Oak Zhang5 小时前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存
门牙咬脆骨6 小时前
【Redis】redis缓存击穿,缓存雪崩,缓存穿透
数据库·redis·缓存
门牙咬脆骨6 小时前
【Redis】GEO数据结构
数据库·redis·缓存
墨鸦_Cormorant7 小时前
使用docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像
redis·nginx·docker
Dlwyz10 小时前
问题: redis-高并发场景下如何保证缓存数据与数据库的最终一致性
数据库·redis·缓存
飞升不如收破烂~11 小时前
redis的List底层数据结构 分别什么时候使用双向链表(Doubly Linked List)和压缩列表(ZipList)
redis
吴半杯13 小时前
Redis-monitor安装与配置
数据库·redis·缓存
会code的厨子14 小时前
Redis缓存高可用集群
redis·缓存