一步一步学习Redis——五大数据类型之哈希(Hash)的相关命令

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 一步一步学习Redis——五大数据类型之哈希(Hash)的相关命令

文章目录:


1.开篇

2.Redis哈希(Hash)的相关命令 

2.1 HSET命令

语法

返回值

2.2 HGET命令 

语法

返回值

2.3 HMSET命令

语法

返回值

2.4 HMGET命令 

语法

返回值

2.5 HSETNX命令

语法

返回值

2.6 HDEL命令

语法

返回值

2.7 HEXISTS命令

语法

返回值

2.8 HKEYS命令

语法

返回值

2.9 HVALS命令 

语法

返回值

2.10 HGETALL命令

语法

返回值

2.11 HLEN命令

语法

返回值

2.12 HINCRBY命令

语法

返回值

2.13 HINCRBYFLOAT命令

语法

返回值

2.14 HSCAN命令

语法

返回值


1.开篇


Redishash是一个 string 类型的 field(字段) value(值)的映射表,hash 特别适合用于存储对象。

Redis中每个 hash 可以存储 232 - 1 键值对(40多亿)。

2.Redis哈希(Hash)的相关命令


序号

命令及描述

1

HDEL key field1 [field2]
删除一个或多个哈希表字段

2

HEXISTS key field
查看哈希表 key 中,指定的字段是否存在。

3

HGET key field
获取存储在哈希表中指定字段的值。

4

HGETALL key
获取在哈希表中指定 key 的所有字段和值

5

HINCRBY key field increment
为哈希表 key 中的指定字段的整数值加上增量 increment

6

HINCRBYFLOAT key field increment
为哈希表 key 中的指定字段的浮点数值加上增量 increment

7

HKEYS key
获取所有哈希表中的字段

8

HLEN key
获取哈希表中字段的数量

9

HMGET key field1 [field2]
获取所有给定字段的值

10

HMSET key field1 value1 [field2 value2]
同时将多个 field-value (-)对设置到哈希表 key 中。

11

HSET key field value
将哈希表 key 中的字段 field 的值设为 value

12

HSETNX key field value
只有在字段 field 不存在时,设置哈希表字段的值。

13

HVALS key
获取哈希表中所有值。

14

HSCAN key cursor [MATCH pattern] [COUNT count]
迭代哈希表中的键值对。

2.1 HSET命令

Redis Hset 命令用于为哈希表中的字段赋值

如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。

如果字段已经存在于哈希表中,旧值将被覆盖。

语法

redis 127.0.0.1:6379> HSET KEY_NAME FIELD VALUE

返回值

如果字段是哈希表中的一个新建字段,并且值设置成功,返回 1 如果哈希表中域字段已经存在且旧值已被新值覆盖,返回 0


2.2 HGET命令 

Redis Hget 命令用于返回哈希表中指定字段的值。

语法

redis 127.0.0.1:6379> HGET KEY_NAME FIELD_NAME

返回值

返回给定字段的值。如果给定的字段或 key 不存在时,返回 nil

2.3 HMSET命令

Redis Hmset 命令用于同时将多个 field-value (字段-)对设置到哈希表中。

此命令会覆盖哈希表中已存在的字段。

如果哈希表不存在,会创建一个空哈希表,并执行 HMSET 操作。

语法

redis 127.0.0.1:6379> HMSET KEY_NAME FIELD1 VALUE1 ...FIELDN VALUEN

返回值

如果命令执行成功,返回 OK


2.4 HMGET命令 

Redis Hmget 命令用于返回哈希表中,一个或多个给定字段的值。

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

语法

redis 127.0.0.1:6379> HMGET KEY_NAME FIELD1...FIELDN

返回值

一个包含多个给定字段关联值的表,表值的排列顺序和指定字段的请求顺序一样。


2.5 HSETNX命令

Redis Hsetnx 命令用于为哈希表中不存在的的字段赋值

如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。

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

如果 key 不存在,一个新哈希表被创建并执行 HSETNX 命令。

语法

redis 127.0.0.1:6379> HSETNX KEY_NAME FIELD VALUE

返回值

设置成功,返回 1 如果给定字段已经存在且没有操作被执行,返回 0

2.6 HDEL命令

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

语法

redis 127.0.0.1:6379> HDEL KEY_NAME FIELD1.. FIELDN

返回值

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

2.7 HEXISTS命令

Redis Hexists 命令用于查看哈希表的指定字段是否存在。

语法

redis 127.0.0.1:6379> HEXISTS KEY_NAME FIELD_NAME

返回值

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

2.8 HKEYS命令

Redis Hkeys 命令用于获取哈希表中的所有域(field)。

语法

redis 127.0.0.1:6379> HKEYS key

返回值

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


2.9 HVALS命令 


Redis Hvals 命令返回哈希表所有域(field)的值。

语法

redis 127.0.0.1:6379> HVALS key

返回值

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

2.10 HGETALL命令

Redis Hgetall 命令用于返回哈希表中,所有的字段和值。

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

语法

redis 127.0.0.1:6379> HGETALL KEY_NAME

返回值

以列表形式返回哈希表的字段及字段值。 key 不存在,返回空列表。

2.11 HLEN命令

Redis Hlen 命令用于获取哈希表中字段的数量。

语法

redis 127.0.0.1:6379> HLEN KEY_NAME

返回值

哈希表中字段的数量。 key 不存在时,返回 0

2.12 HINCRBY命令

Redis Hincrby 命令用于为哈希表中的字段值加上指定增量值。

增量也可以为负数,相当于对指定字段进行减法操作。

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

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

对一个储存字符串值的字段执行 HINCRBY 命令将造成一个错误。

本操作的值被限制在 64 (bit)有符号数字表示之内。

语法

redis 127.0.0.1:6379> HINCRBY KEY_NAME FIELD_NAME INCR_BY_NUMBER

返回值

执行 HINCRBY 命令之后,哈希表中字段的值。

2.13 HINCRBYFLOAT命令

Redis Hincrbyfloat 命令用于为哈希表中的字段值加上指定浮点数增量值。

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

语法

redis 127.0.0.1:6379> HINCRBYFLOAT key field increment
返回值

执行 Hincrbyfloat 命令之后,哈希表中字段的值。

2.14 HSCAN命令

Redis HSCAN 命令用于迭代哈希表中的键值对。

语法

redis 127.0.0.1:6379> HSCAN key cursor [MATCH pattern] [COUNT count]

·       cursor - 游标。

·       pattern - 匹配的模式。

·       count - 指定从数据集里返回多少元素,默认值为 10

返回值

返回的每个元素都是一个元组,每一个元组元素由一个字段(field) 和值(value)组成。



相关文章
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
333 5
|
4月前
|
存储 NoSQL 定位技术
Redis数据类型面试给分情况
Redis常见数据类型包括:string、hash、list、set、zset(有序集合)。此外还包含高级结构如bitmap、hyperloglog、geo。不同场景可选用合适类型,如库存用string,对象存hash,列表用list,去重场景用set,排行用zset,签到用bitmap,统计访问量用hyperloglog,地理位置用geo。
126 5
|
4月前
|
NoSQL Java Redis
Redis基本数据类型及Spring Data Redis应用
Redis 是开源高性能键值对数据库,支持 String、Hash、List、Set、Sorted Set 等数据结构,适用于缓存、消息队列、排行榜等场景。具备高性能、原子操作及丰富功能,是分布式系统核心组件。
555 2
|
8月前
|
NoSQL Redis
Redis的常用数据类型有哪些 ?
Redis 有 5 种基础数据结构,它们分别是:string(字符串)、list(列表)、hash(字典)、set(集 合) 和 zset(有序集合)
|
运维 NoSQL 关系型数据库
|
6月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
1月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
|
2月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
189 1
Redis专题-实战篇二-商户查询缓存
|
1月前
|
缓存 运维 监控
Redis 7.0 高性能缓存架构设计与优化
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。
|
6月前
|
缓存 NoSQL Java
Redis+Caffeine构建高性能二级缓存
大家好,我是摘星。今天为大家带来的是Redis+Caffeine构建高性能二级缓存,废话不多说直接开始~
951 0
下一篇
oss云网关配置