Redis 数据类型hash(哈希)

目录

[1 基本特性](#1 基本特性)

[2 主要操作命令](#2 主要操作命令)

[2.1 设置和获取字段](#2.1 设置和获取字段)

[2.1.1 HSET key field value](#2.1.1 HSET key field value)

[2.1.2 HGET key field](#2.1.2 HGET key field)

[2.1.3 HMSET key field1 value1 [field2 value2 ...]](#2.1.3 HMSET key field1 value1 [field2 value2 ...])

[2.1.4 HMGET key field1 [field2 ...]](#2.1.4 HMGET key field1 [field2 ...])

[2.2 检查字段是否存在](#2.2 检查字段是否存在)

[2.2.1 HEXISTS key field](#2.2.1 HEXISTS key field)

[2.3 获取所有字段和值](#2.3 获取所有字段和值)

[2.3.1 HGETALL key](#2.3.1 HGETALL key)

[2.3.2 HKEYS key](#2.3.2 HKEYS key)

[2.3.3 HVALS key](#2.3.3 HVALS key)

[2.4 删除字段](#2.4 删除字段)

[2.4.1 HDEL key field1 [field2 ...]](#2.4.1 HDEL key field1 [field2 ...])

[2.5 计算字段数量](#2.5 计算字段数量)

[2.5.1 HLEN key](#2.5.1 HLEN key)

[2.6 递增/递减字段值](#2.6 递增/递减字段值)

[2.6.1 HINCRBY key field increment](#2.6.1 HINCRBY key field increment)

[2.6.2 HINCRBYFLOAT key field increment](#2.6.2 HINCRBYFLOAT key field increment)


哈希在 Redis 中是一个键值对集合,适合存储对象。每个哈希可以存储多个字段-值(field-value)对。哈希非常适合存储那些具有多个属性的对象,比如用户信息等。

1 基本特性

  • 键值对集合:哈希是一个键值对的集合,其中每个键关联一个字符串值。这使得哈希可以用来表示复杂的对象,例如包含多个属性的用户记录。

  • 内存效率:哈希在内部使用一种紧凑的表示方式来存储数据,这对于存储大量小对象来说非常高效。当哈希中字段较少时,Redis 使用ziplist编码以节省空间;当字段数量或值大小超过一定阈值时,则转换为hashtable编码。

  • 原子操作:对于单个哈希表的所有命令都是原子性的,这意味着即使有多个客户端同时访问同一个哈希表,它们的操作也不会互相干扰。

  • 部分更新:你可以单独更新哈希中的任何一个字段,而不需要重新写入整个哈希。

  • 性能:哈希的字段读写非常高效,特别是当字段数量较少时。

2 主要操作命令

2.1 设置和获取字段
2.1.1 HSET key field value

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

127.0.0.1:6379> HSET user:1 name "Alice" age 25
(integer) 2
2.1.2 HGET key field

获取哈希表 key 中字段 field 的值。

127.0.0.1:6379> hget user:1 name
"Alice"
2.1.3 HMSET key field1 value1 [field2 value2 ...]

同时设置多个字段值(从 Redis 4.0 开始推荐使用 HSET 的多参数形式)。

127.0.0.1:6379> hmset user:2 name "jack" age 29
OK
2.1.4 HMGET key field1 [field2 ...]

同时获取多个字段的值。

127.0.0.1:6379> hmget user:2 name age
1) "jack"
2) "29"
2.2 检查字段是否存在
2.2.1 HEXISTS key field

检查哈希表 key 中是否存在字段 field。存在field属性返回1,不存在返回0。

127.0.0.1:6379> hexists user:2 name
(integer) 1
127.0.0.1:6379> hexists user:2 email
(integer) 0
2.3 获取所有字段和值
2.3.1 HGETALL key

获取哈希表 key 中所有的字段和值。

127.0.0.1:6379> hgetall user:2
1) "name"
2) "jack"
3) "age"
4) "29"
2.3.2 HKEYS key

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

127.0.0.1:6379> hkeys user:2
1) "name"
2) "age"
2.3.3 HVALS key

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

127.0.0.1:6379> hvals user:2
1) "jack"
2) "29"
2.4 删除字段
2.4.1 HDEL key field1 [field2 ...]

删除哈希表 key 中的一个或多个字段。

127.0.0.1:6379> hdel user:2 age
(integer) 1
127.0.0.1:6379> hkeys user:2
1) "name"
2.5 计算字段数量
2.5.1 HLEN key

返回哈希表 key 中字段的数量。

127.0.0.1:6379> hlen user:2
(integer) 1
2.6 递增/递减字段值
2.6.1 HINCRBY key field increment

将哈希表 key 中的字段 field 的整数值增加指定的增量。

XML 复制代码
127.0.0.1:6379> hgetall user:1
1) "name"
2) "Alice"
3) "age"
4) "25"
127.0.0.1:6379> hincrby user:1 age 4
(integer) 29
127.0.0.1:6379> hget user:1 age
"29"
2.6.2 HINCRBYFLOAT key field increment

将哈希表 key 中的字段 field 的浮点数值增加指定的增量。

XML 复制代码
127.0.0.1:6379> hincrbyfloat user:1 age 0.50
"29.5"

更多命令请参考:Commands | Docs

相关推荐
Oak Zhang26 分钟前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存
聂 可 以1 小时前
Windows环境安装MongoDB
数据库·mongodb
web前端神器1 小时前
mongodb多表查询,五个表查询
数据库·mongodb
门牙咬脆骨1 小时前
【Redis】redis缓存击穿,缓存雪崩,缓存穿透
数据库·redis·缓存
门牙咬脆骨1 小时前
【Redis】GEO数据结构
数据库·redis·缓存
wusong9992 小时前
mongoDB回顾笔记(一)
数据库·笔记·mongodb
代码小鑫2 小时前
A043-基于Spring Boot的秒杀系统设计与实现
java·开发语言·数据库·spring boot·后端·spring·毕业设计
changuncle2 小时前
MongoDB数据备份与恢复(内含工具下载、数据处理以及常见问题解决方法)
数据库·mongodb
久醉不在酒2 小时前
MySQL数据库运维及集群搭建
运维·数据库·mysql
WindFutrue2 小时前
使用Mybatis向Mysql中的插入Point类型的数据全方位解析
数据库·mysql·mybatis