redis 数据类型新手练习系列——Hash类型

redis 数据类型

Redis 主要支持以下几种数据类型:

(1)string(字符串): 基本的数据存储单元,可以存储字符串、整数或者浮点数。

(2)hash(哈希):一个键值对集合,可以存储多个字段。

(3)list(列表):一个简单的列表,可以存储一系列的字符串元素。

(4)set(集合):一个无序集合,可以存储不重复的字符串元素。

(5)zset(sorted set:有序集合): 类似于集合,但是每个元素都有一个分数(score)与之关联。

(6)位图(Bitmaps):基于字符串类型,可以对每个位进行操作。

(7)超日志(HyperLogLogs):用于基数统计,可以估算集合中的唯一元素数量。

(8)地理空间(Geospatial):用于存储地理位置信息。

(9)发布/订阅(Pub/Sub):一种消息通信模式,允许客户端订阅消息通道,并接收发布到该通道的 消息。

(10)流(Streams):用于消息队列和日志存储,支持消息的持久化和时间排序。

(11)模块(Modules):Redis 支持动态加载模块,可以扩展 Redis 的功能。

使用:

key-string:最常用的,一般用于存储一个值。

key-hash:存储一个对象数据的。

key-list:使用list结构实现栈和队列结构。 分布式锁 红锁

key-set:交集,差集和并集的操作。

key-zset:排行榜,积分存储等操作。

Hash类型

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

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

详情 指令

(1)hset key field value
功能:为哈希表中的字段设置值。
(2)hget key field
功能:获取哈希表中指定字段的值。
(3)hmset key field1 value1 field2 value2 ...
功能:为哈希表设置多个字段和值。

在哈希表user:1中,设置多个字段和值。

(4)hmget key field1 field2 ...
功能:获取哈希表中多个字段的值。
(5)hgetall key
功能:获取哈希表中所有字段和值。
(6)hdel key field1 field2
功能:删除哈希表中一个或多个字段。
(7)hexists key field
功能:检查哈希表中是否存在指定字段。
(8)hkeys key
功能:获取哈希表中所有字段。
(9)hvals key
功能:获取哈希表中所有值。
(10)hlen key
功能:获取哈希表中字段的数量。
(11)hincrby key field increment
功能:将哈希表中指定字段的值增加指定数值(仅适用于整数)。
(12)hincrbyfloat key field increment
功能:将哈希表中指定字段的值增加指定数值(适用于浮点数)。
(13)hsetnx key field value
功能:仅当字段不存在时设置值。

如果字段不存在,则设置;否则不操作。

其他类型详情可查看本人同系列博客

相关推荐
不知名的老吴1 分钟前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU1 分钟前
三大范式和E-R图
数据库
一江寒逸12 分钟前
零基础从入门到精通MySQL(上篇):筑基篇——吃透核心概念与基础操作,打通SQL入门第一关
数据库·sql·mysql
@土豆14 分钟前
Ubuntu 22.04 运行 Filebeat 7.11.2 崩溃问题分析及解决文档
linux·数据库·ubuntu
计算机安禾22 分钟前
【数据结构与算法】第35篇:归并排序与基数排序
c语言·数据结构·vscode·算法·排序算法·哈希算法·visual studio
专注API从业者26 分钟前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫
头疼的程序员27 分钟前
计算机网络:自顶向下方法(第七版)第八章 学习分享(三)
网络·学习·计算机网络
Devin~Y33 分钟前
高并发电商与AI智能客服场景下的Java面试实战:从Spring Boot到RAG与向量数据库落地
java·spring boot·redis·elasticsearch·spring cloud·kafka·rag
爱码小白34 分钟前
MySQL 单表查询练习题汇总
数据库·python·算法
WangJunXiang636 分钟前
第09章:PostgreSQL日常维护
数据库·postgresql