Redis基本数据类型哈希Hash常用操作命令

 更新时间:2022年05月31日 14:49:11   作者:把苹果咬哭的测试笔记  
这篇文章主要为大家介绍了Redis基本数据类型哈希Hash常用操作,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

Redis数据类型Hash常用操作

redis里的hash是一个string类型的field(字段)和value(值)的映射表。特别适合用于存储对象,每个hash可以存储40多亿键值对。

熟悉python的童鞋可以想象成字典dict。之前的数据类型存储都是k-v这样,而hash的存储就是k-dictdict里又会有属于自己的k-v

一、hset

为哈希表中的字段赋值,如果哈希表不存在,创建一个新的哈希表被并进行hset操作。
如果字段已经存在于哈希表中,旧值将被覆盖。

hset myhash k1 v1

二、hget

返回哈希表中指定字段的值,如果给定的字段或 key 不存在时,返回 nil。

hget myhash k1

三、hmset

同时将多个 field-value 对设置到哈希表中。

hmset myhash k2 v2 k3 v3

如果哈希表中已存在的字段,则覆盖。
如果哈希表不存在,会创建一个空哈希表,并执行hset操作。

四、hmget

返回哈希表中,一个或多个给定字段的值。

hmget myhash k1 k2 k3 k4

如果指定的字段不存在于哈希表,那么返回一个nil值。

五、hgetall

返回哈希表中,所有的字段和值。

hgetall myhash

注意,在返回值里,紧跟每个字段名(field name)之后是字段的值(value),所以返回值的长度是哈希表大小的两倍。

六、hdel

删除哈希表 key 中的一个或多个指定字段,不存在的字段将被忽略。

hdel myhash k2 k3 k5

返回的是被成功删除字段的数量,不包括被忽略的字段。

七、hlen

获取哈希表中字段的数量。

hlen myhash

八、hexists

查看哈希表的指定字段是否存在。

hexists myhash k1

如果哈希表含有给定字段,返回 1。
如果哈希表不含有给定字段,或 key 不存在,返回 0 。

九、hkeys

获取哈希表中的所有字段(field)。

hkeys myhash

包含哈希表中所有字段(field)列表。 当 key 不存在时,返回一个空列表。

十、hvals

返回哈希表所有字段(field)的值。

hvals myhash

返回一个包含哈希表中所有字段(field)值的列表。 当 key 不存在时,返回一个空表。

十一、hincrby

为哈希表中的字段值加上指定增量值,这个增量也可以是负数,相当于减法。

若哈希表的 key 不存在,创建一个新的哈希表被并执行hincrby命令。

若指定的字段不存在,那么在执行命令前,字段的值被初始化为 0 。

若对储存字符串值的字段执行,会报错。

十二、hsetnx

为哈希表中不存在的的字段赋值。

若哈希表不存在,创建新的哈希表并进行 hset 操作。

如果字段已经存在于哈希表中,操作无效。

如果key不存在,创建新哈希表并执行hsetnx命令。

关于redis中hash的应用,比如保存用户信息数据、经常变动的信息,如果不想使用传统的k-v对象去存储,可以用redis的hash。

以上就是Redis基本数据类型哈希Hash常用命令操作的详细内容,更多关于Redis数据类型哈希Hash操作命令的资料请关注程序员之家其它相关文章!

相关文章

  • 基于Redis实现分布式锁以及任务队列

    基于Redis实现分布式锁以及任务队列

    这篇文章主要介绍了基于Redis实现分布式锁以及任务队列,需要的朋友可以参考下
    2015-11-11
  • redis redistemplate序列化对象配置方式

    redis redistemplate序列化对象配置方式

    这篇文章主要介绍了redis redistemplate序列化对象配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Redis内存满了的几种原因和最佳解决方案

    Redis内存满了的几种原因和最佳解决方案

    Redis是一款高性能的内存数据库,被广泛应用于缓存、消息队列、计数器等场景,然而,由于Redis是基于内存的数据库,当数据量过大或者配置不合理时,就有可能导致Redis的内存满,本文将介绍Redis内存满的几种原因,并提供相应的解决方案,需要的朋友可以参考下
    2023-11-11
  • 浅谈Redis的keys命令到底有多慢

    浅谈Redis的keys命令到底有多慢

    本文主要介绍了浅谈Redis的keys命令到底有多慢,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Redis进行相关优化详解

    Redis进行相关优化详解

    这篇文章主要介绍了Redis进行相关优化,Redis在项目中进行广泛使用,那么在日常的开发过程中,我们在使用Redis的过程中需要注意那些呢?本文将从三个维度来讲解如何进行Redis的优化
    2022-08-08
  • 浅谈Redis哨兵模式高可用解决方案

    浅谈Redis哨兵模式高可用解决方案

    Redis高可用有两种模式:哨兵模式和集群模式,本文基于哨兵模式搭建一主两从三哨兵Redis高可用服务,感兴趣的可以了解一下
    2022-03-03
  • Redis过期键与内存淘汰策略深入分析讲解

    Redis过期键与内存淘汰策略深入分析讲解

    因为redis数据是基于内存的,然而内存是非常宝贵的资源,然后我们就会对一些不常用或者只用一次的数据进行存活时间设置,这样才能提高内存的使用效率,下面这篇文章主要给大家介绍了关于Redis中过期键与内存淘汰策略,需要的朋友可以参考下
    2022-11-11
  • 一文掌握Redis的三种集群方案(小结)

    一文掌握Redis的三种集群方案(小结)

    这篇文章主要介绍了一文掌握Redis的三种集群方案(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Redis分布式限流组件设计与使用实例

    Redis分布式限流组件设计与使用实例

    本文主要讲解基于 自定义注解+Aop+反射+Redis+Lua表达式 实现的限流设计方案。实现的限流设计与实际使用。具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • 为何Redis使用跳表而非红黑树实现SortedSet

    为何Redis使用跳表而非红黑树实现SortedSet

    本篇文章主要介绍了为何Redis使用跳表而非红黑树实现SortedSet,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论

?


http://www.vxiaotou.com