【Redis】Hash类型介绍

【Redis】Hash类型介绍

目录

一、简介

在 Redis 中,哈希类型是指值本⾝⼜是⼀个键值对结构,形如 key = “key”,value = { { field1, value1 }, …, {fieldN, valueN} },在Redis中为了与key - value作区分,将Hash类型键值对结构表示为filed - value。

String与Hash对比图:

二、相关命令

2.1 hset 和 hget

hset: 设置 hash 中指定的字段(field)的值(value)。

语法:hset key field value [field value ...]
命令有效版本:2.0.0 之后

时间复杂度:插⼊⼀组 field 为 O(1), 插⼊ N 组 field 为 O(N)
返回值:添加的字段的个数。

也可以当修改字段的效果:

hget:获取 hash 中指定字段的值。

语法:hget key filed

命令有效版本:2.0.0 之后

时间复杂度:O(1)
返回值:字段对应的值或者 nil。

2.2 hexists

hexists判断 hash 中是否有指定的字段。

语法:hexists key filed

命令有效版本:2.0.0 之后

时间复杂度:O(1)
返回值:1 表⽰存在,0 表⽰不存在。

2.3 hdel

hdel删除 hash 中指定的字段。

语法:hdel key field [field ...]

命令有效版本:2.0.0之后

时间复杂度:删除⼀个元素为 O(1). 删除 N 个元素为 O(N).
返回值:本次操作删除的字段个数。

2.4 hkeys

hkeys获取 hash 中的所有字段。

语法:hkeys key

命令有效版本:2.0.0 之后

时间复杂度:O(N), N 为 field 的个数.
返回值:字段列表。

2.5 hvals

hvals 获取 hash 中的所有的值。

语法:hvals key

命令有效版本:2.0.0 之后

时间复杂度:O(N), N 为 field 的个数.
返回值:Hash所有value列表。

2.6 hgetall

hgetall获取 hash 中的所有的字段和值。

语法:hgetall key

命令有效版本:2.0.0 之后

时间复杂度:O(N), N 为 field 的个数.
返回值:Hash所有字段和对应的值。

2.7 hmget

hmget⼀次获取 hash 中多个字段的值。

hmget key field [field ...]

命令有效版本:2.0.0 之后

时间复杂度:只查询⼀个元素为 O(1), 查询多个元素为 O(N), N 为查询元素个数.
返回值:字段对应的值或者 nil。

2.8 hlen

hlen获取 hash 中的所有字段的个数。

语法:hlen key

命令有效版本:2.0.0 之后

时间复杂度:O(1)
返回值:字段个数。

2.9 hsetnx

hsetnx在字段不存在的情况下,设置 hash 中的字段和值。

语法:hsetnx key field value

命令有效版本:2.0.0 之后

时间复杂度:O(1)
返回值:1表⽰设置成功,0 表⽰失败。

2.10 hincrby

hincrby将 hash 中字段对应的数值(必须是整数)添加指定的值。

语法: hincrby key field increment

命令有效版本:2.0.0之后

时间复杂度:O(1)
返回值:该字段变化之后的值。

2.11 hincrbyfloat

hincrbyfloathincrby的浮点数版本, 将 hash 中字段对应的数值(可以是整数和浮点数)添加指定的值。

语法: hincrbyfloat key field increment

命令有效版本:2.6.0之后

时间复杂度:O(1)
返回值:该字段变化之后的值。

2.12 小结

命令执⾏效果时间复杂度
hset key field value设置值O(1)
hget key field获取值O(1)
hdel key field [field …]删除 fieldO(k), k 是 field 个数
hlen key计算 field 个数O(1)
hgetall key获取所有的 field-valueO(k), k 是 field 个数
hmget key field [field …]批量获取 field-valueO(k), k 是 field 个数
hmset key field value [field value …]批量获取 field-valueO(k), k 是 field 个数
hexists key field判断 field 是否存在O(1)
hkeys key获取所有的 fieldO(k), k 是 field 个数
hvals key获取所有的 valueO(k), k 是 field 个数
hsetnx key field value设置值,但必须在 field 不存在时才能设置成功O(1)
hincrby key field n对应 field-value +nO(1)
hincrbyfloat key field n对应 field-value +nO(1)
hstrlen key field计算 value 的字符串⻓度O(1)

三、编码方式

哈希的内部编码有两种:

  • ziplist(压缩列表):当哈希类型元素个数⼩于 hash-max-ziplist-entries 配置(默认 512 个)、同时所有值都⼩于 hash-max-ziplist-value 配置(默认 64 字节)时,Redis 会使⽤ ziplist 作为哈希的内部实现,ziplist 使⽤更加紧凑的结构实现多个元素的连续存储,所以在节省内存⽅⾯⽐ hashtable 更加优秀。
  • hashtable(哈希表):当哈希类型⽆法满⾜ ziplist 的条件时,Redis 会使⽤ hashtable 作为哈希的内部实现,因为此时 ziplist 的读写效率会下降,⽽ hashtable 的读写时间复杂度为 O(1)。

四、应用场景

4.1 作为缓存

存储结构化的数据的时候,使用 hash 更加合适。

使用hash表示:

Read more

RUST:异步代码的测试与调试艺术

RUST:异步代码的测试与调试艺术

RUST:异步代码的测试与调试艺术 一、异步测试的本质与难点 1.1 异步测试与同步测试的区别 💡在Rust同步编程中,测试通常是顺序执行的,每个测试函数会阻塞线程直到完成,结果是确定的。而异步测试的结果可能受到任务调度、网络延迟、数据库连接等因素的影响,时序性和状态管理更加复杂。 同步测试示例: #[cfg(test)]modtests{#[test]fntest_add(){assert_eq!(1+1,2);}} 异步测试示例(使用Tokio测试宏): #[cfg(test)]modtests{usetokio::time::sleep;usestd::time::Duration;#[tokio::test]asyncfntest_async_add(){sleep(Duration::from_millis(100)).await;assert_

By Ne0inhk
前端状态管理,终于要迎来“大结局”了?

前端状态管理,终于要迎来“大结局”了?

在这个前端技术更迭比天气还快的时代,我们似乎正处于一个微妙的临界点。React 统治了过去十年,Vue 赢得了开发者的心,但当我们回过头看,复杂的“心智负担”和“性能损耗”依然是挥之不去的阴影。 最近,Signals(信号) 这个概念在 SolidJS、Preact、Qwik 甚至 Angular 中全线爆发,连 Vue 也一直深耕于此。 今天,我们就来聊聊这个让前端圈再次“躁动”的底层逻辑:Signals 究竟是什么?它会是状态管理的终点吗? 01 范式演进:从“全量刷新”到“精确制导” 要理解 Signals,必须先看清它的对手:Virtual DOM(虚拟 DOM)。 在 React 的世界观里,状态改变 = 重新执行函数

By Ne0inhk

【Web实时通信安全指南】:用PHP实现WebSocket TLS+AES双重加密

第一章:Web实时通信安全概述 Web实时通信(WebRTC)作为一种支持浏览器间直接音视频通话与数据传输的技术,已在在线会议、远程教育和即时通讯等领域广泛应用。然而,其实时性与点对点连接特性也带来了独特的安全挑战。由于通信数据往往不经过中心服务器中转,确保传输过程中的机密性、完整性和身份真实性成为关键。 安全威胁模型 WebRTC面临的主要安全风险包括: * 信令劫持:攻击者通过篡改信令消息诱导建立恶意连接 * IP地址泄露:STUN/TURN协议可能暴露用户真实IP地址 * 中间人攻击:缺乏有效证书验证可能导致会话被监听或篡改 核心安全机制 WebRTC内置了多层次的安全保障措施: 1. 使用DTLS(数据报传输层安全)加密媒体流 2. 采用SRTP(安全实时传输协议)保护音视频数据 3. 通过ICE框架配合STUN/TURN服务器实现NAT穿透的同时控制访问范围 加密通道建立示例 以下代码展示了如何在创建RTCPeerConnection时强制启用加密: // 创建带安全配置的PeerConnection const pc = new RTCPe

By Ne0inhk
【开题答辩全过程】以 基于web的高校学生会管理系统的设计与实现为例,包含答辩的问题和答案

【开题答辩全过程】以 基于web的高校学生会管理系统的设计与实现为例,包含答辩的问题和答案

个人简介 一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等 开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。 感谢大家的关注与支持! 各位老师好!我是xx同学,我的毕业设计题目是《基于web的高校学生会管理系统的设计与实现》。随着校园活动日益丰富,传统人工管理方式效率低下且容易出错,因此我打算开发一套B/S架构的管理系统来解决这些问题。系统主要包含四大功能模块:学生会干部成员信息管理(档案、换届、奖惩)、财务管理(资金使用查询、信贷管理、余额情况及物品借还登记)、日常事务管理(各部门工作计划、活动安排、纳新信息)以及文件管理(上下级文件传递、日常文件登记)。技术栈方面,我计划采用前后端分离模式,前端使用Vue或React框架,后端采用Spring Boot或Node.js,

By Ne0inhk