【Redis】五大常见的数据类型之 Hash

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 我们都知道 Redis 提供了丰富的数据类型,常见的有五种:String,Hash,List,Set、Zset。今天我们就来详细的聊聊 Redis 这五大常见的数据类型之一 Hash;

前言

我们都知道 Redis 提供了丰富的数据类型,常见的有五种:String(字符串),Hash(哈希),List(列表),Set(集合)、Zset(有序集合)

今天我们就来详细的聊聊 Redis 这五大常见的数据类型之一 Hash

结构类型 结构存储的值 结构读写能力
Hash 包含键值对的无序散列表; 添加,获取,删除单个元素;

应用场景:缓存对象、购物车等。

 

概述简介

Hash 是一个键值对(key-value)集合,其中 value 的形式如: value=[{field1,value1},...{fieldN,valueN}]Hash 特别适合用于存储对象。

HashString 对象的区别如下图所示:

内部实现

Hash 类型的底层数据结构是由压缩列表或哈希表实现的:

  • 如果哈希类型元素个数小于 512 个(默认值,可由 hash-max-ziplist-entries 配置),所有值小于 64 字节(默认值,可由 hash-max-ziplist-value 配置)的话,Redis 会使用压缩列表作为 Hash 类型的底层数据结构;
  • 如果哈希类型元素不满足上面条件,Redis 会使用哈希表作为 Hash 类型的底层数据结构。

在最新 Redis 版本中,压缩列表数据结构已经废弃了,交由 listpack 数据结构来实现了

 

常用命令

# 存储一个哈希表 key 的键值
#  HSET key field value [field value ...]
127.0.0.1:6379> HSET usr1 name sid10t
(integer) 1
127.0.0.1:6379> HSET usr1 name sid10t age 19
(integer) 1

# 获取哈希表 key 对应的 field 键值
# HGET key field
127.0.0.1:6379> HGET usr1 name
"sid10t"

# 在一个哈希表 key 中存储多个键值对
# HMSET key field value [field value...] 
127.0.0.1:6379> HMSET usr2 name sidiot age 18
OK

# 批量获取哈希表 key 中多个 field 键值
# HMGET key field [field ...]       
127.0.0.1:6379> HMGET usr2 name age
1) "sidiot"
2) "18"

# 删除哈希表 key 中的 field 键值
# HDEL key field [field ...]    
127.0.0.1:6379> HDEL usr1 age
(integer) 1
127.0.0.1:6379> HDEL usr2 name age
(integer) 2

# 返回哈希表 key 中 field 的数量
# HLEN key
127.0.0.1:6379> HLEN usr1
(integer) 1
127.0.0.1:6379> HLEN usr2
(integer) 0

# 返回哈希表 key 中所有的键值
# HGETALL key 
127.0.0.1:6379> HGETALL usr1
1) "name"
2) "sid10t"
127.0.0.1:6379> HGETALL usr2
(empty array)

# 为哈希表 key 中 field 键的值加上增量 increment
# HINCRBY key field increment
127.0.0.1:6379> HINCRBY usr1 age 1
(integer) 19

# 判断哈希表中指定的 field 是否存在
# HEXISTS key field
127.0.0.1:6379> HEXISTS usr1 name
(integer) 1
127.0.0.1:6379> HEXISTS usr1 info
(integer) 0

# 获取哈希表中的所有 field
# HKEYS key
127.0.0.1:6379> HKEYS usr1
1) "name"
2) "age"
127.0.0.1:6379> HKEYS usr2
(empty array)

# 获取哈希表中的所有 value
# HVALS key
127.0.0.1:6379> HVALS usr1
1) "sid10t"
2) "19"
127.0.0.1:6379> HVALS usr2
(empty array)

 

应用场景

缓存对象

Hash 类型的 (key,field, value) 的结构与对象的(对象 id, 属性, 值)的结构相似,也可以用来存储对象。

我们以用户信息为例,它在关系型数据库中的结构是这样的:

uid name age
1 sid10t 18
2 sidiot 16

我们可以使用如下命令,将用户对象的信息存储到 Hash 类型:

# 存储一个哈希表 uid:1 的键值
127.0.0.1:6379> HSET uid1 name sid10t age 18
(integer) 2

# 存储一个哈希表 uid:2 的键值
127.0.0.1:6379> HSET uid2 name sidiot age 16
(integer) 2

# 获取哈希表用户 id 为1中所有的键值
127.0.0.1:6379> HGETALL uid1
1) "name"
2) "sid10t"
3) "age"
4) "18"

# ...

Redis Hash 存储结构如下图:

在介绍 String 类型的应用场景时有所介绍,String + Json 也是存储对象的一种方式,那么存储对象时,到底用 String + json 还是用 Hash 呢?

一般对象用 String + Json 存储,对象中某些频繁变化的属性可以考虑抽出来用 Hash 类型存储。

购物车

以用户 id 为 key,商品 id 为 field,商品数量为 value,恰好构成了购物车的3个要素,如下图所示。

涉及的命令如下:

  • 添加商品:HSET cart:{用户id} {商品id} 1
  • 添加数量:HINCRBY cart:{用户id} {商品id} 1
  • 商品总数:HLEN cart:{用户id}
  • 删除商品:HDEL cart:{用户id} {商品id}
  • 获取购物车所有商品:HGETALL cart:{用户id}

当前仅仅是将商品 ID 存储到了 Redis 中,在回显商品具体信息的时候,还需要拿着商品 id 查询一次数据库,获取完整的商品的信息。

后记

Redis 五大常见数据类型之一的 Hash 就先讲到这里了,后续还会有其他类型的讲解呢,敬请关注!

参考资料:

📝 上篇精讲: 【Redis】五大常见的数据类型之 String
💖 我是  𝓼𝓲𝓭𝓲𝓸𝓽,期待你的关注;
👍 创作不易,请多多支持;
🔥 系列专栏: Redis
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
17天前
|
存储 NoSQL Java
Redis如何处理Hash冲突?
在 Redis 中,哈希表是一种常见的数据结构,通常用于存储对象的属性,对于哈希表,最常遇到的是哈希冲突,那么,当 Redis遇到Hash冲突会如何处理?这篇文章,我们将详细介绍Redis如何处理哈希冲突,并探讨其性能和实现细节。
38 1
|
1天前
|
存储 NoSQL Redis
Redis 哈希(Hash)
10月更文挑战第16天
11 1
|
2天前
|
存储 消息中间件 NoSQL
Redis 数据类型
10月更文挑战第15天
8 1
|
14天前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
21 3
|
27天前
|
存储 消息中间件 缓存
深入探析Redis常见数据类型及应用场景
深入探析Redis常见数据类型及应用场景
34 2
|
1月前
|
存储 JSON NoSQL
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
这篇文章是关于Redis基本数据结构的学习笔记,包括了String、Hash、Set、List和SortedSet的介绍和常用命令。文章解释了每种数据结构的特点和使用场景,并通过命令示例演示了如何在Redis中操作这些数据结构。此外,还提供了一些练习示例,帮助读者更好地理解和应用这些数据结构。
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
|
2月前
|
NoSQL 安全 Java
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
这篇文章深入探讨了Redis中的String数据类型,包括键操作的命令、String类型的命令使用,以及String在Redis中的内部数据结构实现。
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
|
27天前
|
存储 NoSQL 算法
5)深度解密 Redis 的哈希(Hash)
5)深度解密 Redis 的哈希(Hash)
23 0
|
2月前
|
存储 NoSQL 算法
Redis6入门到实战------ 三、常用五大数据类型(列表(List)、集合(Set)、哈希(Hash)、Zset(sorted set))
这是关于Redis 6入门到实战的文章,具体内容涉及Redis的五大数据类型:列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset(sorted set))。文章详细介绍了这些数据类型的特点、常用命令以及它们背后的数据结构。如果您有任何关于Redis的具体问题或需要进一步的帮助,请随时告诉我。
|
2月前
|
消息中间件 存储 NoSQL
redis实战——go-redis的使用与redis基础数据类型的使用场景(一)
本文档介绍了如何使用 Go 语言中的 `go-redis` 库操作 Redis 数据库
117 0
redis实战——go-redis的使用与redis基础数据类型的使用场景(一)