当前位置: 首页 > news >正文

redis基本数据结构-hash

这里写自定义目录标题

    • 1. redis的数据结构hash
      • 1.1 Hash 数据结构的特点
      • 1.2 常见命令
      • 1.3 适用示例
    • 2. 常见业务场景
      • 2.1 用户信息存储
        • 2.1.1 场景
        • 2.1.2 优势
        • 2.1.3 解决方案
        • 2.1.4 代码实现
      • 2.2 购物车管理
        • 2.2.1 背景
        • 2.2.2 优势
        • 2.2.3 解决方案
        • 2.2.4 代码实现
    • 3. 注意事项:

1. redis的数据结构hash

参考链接:https://mp.weixin.qq.com/s/srkd73bS2n3mjIADLVg72A
Redis 的 Hash 数据结构是一种键值对集合,它非常适合表示对象或实体的属性。每个 Hash 可以存储多个字段,每个字段则对应一个值,这使得 Hash 成为一种高效的存储和查询方式,尤其是在处理对象数据时。

1.1 Hash 数据结构的特点

  • 节省空间: 对于存储多个字段的小对象,Hash 可以节省内存,因为 Redis 会对小的 Hash 结构进行内部优化。
  • 方便操作: 可以单独操作 Hash 中的字段,而不需要序列化整个对象。这个相较于string数据结构而已的显著特点。
  • 快速访问: 通过字段名快速访问对应的值,适合频繁读取和更新的场景。

1.2 常见命令

以下是一些常用的 Redis Hash 命令:
HSET: 设置 Hash 中指定字段的值。
HGET: 获取 Hash 中指定字段的值。
HMSET: 设置多个字段的值。
HMGET: 获取多个字段的值。
HGETALL: 获取 Hash 中所有字段和值。
HDEL: 删除 Hash 中指定字段。
HINCRBY: 对 Hash 中的字段值进行增减。
HEXISTS: 检查 Hash 中是否存在指定字段。

1.3 适用示例

# 创建用户 1000 的 Hash
HSET user:1000 name "Alice" age 30 city "New York"
# 查询用户姓名
HGET user:1000 name
# 返回 "Alice"
# 更新用户城市
HSET user:1000 city "Los Angeles"
# 查询所有用户信息
HGETALL user:1000
# 返回 {"name": "Alice", "age": "30", "city": "Los Angeles"}
# 增加用户年龄
HINCRBY user:1000 age 1
# 查询用户年龄
HGET user:1000 age
# 返回 "31"
# 删除用户年龄字段
HDEL user:1000 age

2. 常见业务场景

  1. 用户信息存储: 在社交网络或电商平台中,每个用户的基本信息(如姓名、地址、年龄等)可以使用 Hash 存储,方便快速读取和更新。
  2. 商品属性管理: 在电商平台中,商品的属性(如名称、价格、库存等)可以存储为 Hash,便于管理和查询。
  3. 会话管理: 在 Web 应用中,可以使用 Hash 来存储用户的会话信息,如登录状态、购物车内容等。
  4. 统计信息: 对于需要频繁更新的统计数据(如访问量、点赞数等),可以使用 Hash 来存储并进行原子性增减操作。
  5. 配置管理: 使用 Hash 存储应用程序的配置项,方便快速修改和读取。

2.1 用户信息存储

2.1.1 场景

在社交网络应用中,每个用户都有一系列属性,如用户名、年龄、兴趣爱好等。使用Hash类型可以方便地存储和查询单个用户的详细信息。

2.1.2 优势
  1. 结构化存储:将用户信息以字段和值的形式存储,易于理解和操作。
  2. 快速读写:Redis的Hash操作提供高速的读写性能。
  3. 灵活更新:可以单独更新用户信息中的某个字段,而无需重新设置整个对象。
2.1.3 解决方案

使用Redis Hash类型来存储和管理用户信息。当用户信息更新时,只更新Hash中的对应字段。
在这里插入图片描述

2.1.4 代码实现
package mainimport ("context""fmt""github.com/go-redis/redis/v8""log"
)var ctx = context.Background()// Redis 客户端初始化
var rdb = redis.NewClient(&redis.Options{Addr:     "",  // Redis 服务器地址Password: "", // 密码DB:       0,                  // 使用默认 DB
})// 存储用户信息到 Redis Hash
func storeUserInfo(userID string, userInfo map[string]interface{}) {hashKey := "user:" + userID// 将用户信息存储到 Redis 的 Hash 中err := rdb.HSet(ctx, hashKey, userInfo).Err()if err != nil {log.Fatalf("Error storing user info: %v", err)}
}// 从 Redis Hash 获取用户信息
func getUserInfo(userID string) map[string]string {hashKey := "user:" + userID// 从 Redis 获取用户信息fields, err := rdb.HGetAll(ctx, hashKey).Result()if err != nil {log.Fatalf("Error getting user info: %v", err)return nil}return fields
}func main() {// 示例用户信息userID := "12345"userInfo := map[string]interface{}{"username":  "john_doe","age":       30,"interests": "coding, hiking, reading",}// 存储用户信息storeUserInfo(userID, userInfo)// 获取并显示用户信息retrievedUserInfo := getUserInfo(userID)fmt.Printf("Retrieved User Info: %+v\n", retrievedUserInfo)
}

在这里插入图片描述

2.2 购物车管理

2.2.1 背景

在电商平台中,用户的购物车需要记录用户选择的商品及其数量。使用Hash类型可以有效地管理每个用户的购物车。

2.2.2 优势
  1. 快速添加和修改:可以快速添加商品到购物车或更新商品数量。
  2. 批量操作:可以一次性获取或更新购物车中的多个商品。
2.2.3 解决方案

使用Redis Hash类型来实现购物车功能,每个用户的购物车作为一个独立的Hash存储。
在这里插入图片描述

2.2.4 代码实现
package mainimport ("context""fmt""github.com/go-redis/redis/v8""log""strconv"
)var ctx = context.Background()// Redis 客户端初始化
var rdb = redis.NewClient(&redis.Options{Addr:     "",  // Redis 服务器地址Password: "", // 密码DB:       0,                  // 使用默认 DB
})// 添加商品到购物车
func addToCart(cartID string, productID string, quantity int) {cartKey := "cart:" + cartID// 使用 HINCRBY 命令增加商品数量err := rdb.HIncrBy(ctx, cartKey, productID, int64(quantity)).Err()if err != nil {log.Fatalf("Error adding to cart: %v", err)}
}// 获取购物车中的商品和数量
func getCart(cartID string) map[string]int {cartKey := "cart:" + cartID// 从 Redis 获取购物车内容items, err := rdb.HGetAll(ctx, cartKey).Result()if err != nil {log.Fatalf("Error getting cart: %v", err)return nil}// 将商品 ID 和数量转换为映射cart := make(map[string]int)for productID, quantity := range items {qty, err := strconv.Atoi(quantity)if err != nil {log.Printf("Error converting quantity for product %s: %v", productID, err)continue}cart[productID] = qty}return cart
}func main() {// 示例购物车 ID 和商品cartID := "user:123:cart"addToCart(cartID, "product:1", 2)addToCart(cartID, "product:2", 3)addToCart(cartID, "product:1", 1) // 增加产品 1 的数量// 获取并显示购物车内容cart := getCart(cartID)fmt.Println("Shopping Cart Contents:")for productID, quantity := range cart {fmt.Printf("Product ID: %s, Quantity: %d\n", productID, quantity)}
}

在这里插入图片描述
也可以根据hash的命令扩展功能。

3. 注意事项:

  • Hash类型的字段值可以是字符串,最大容量为512MB。
  • 在并发环境下,应确保对Hash的操作是线程安全的,可以使用事务或Lua脚本来保证。
  • 存储较大的Hash时,应注意性能和内存使用情况,合理设计数据结构以避免过度膨胀。
  • 定期清理和维护Hash数据,避免数据冗余和失效数据的累积。
    简单用lua脚本的形式:
// 添加商品到购物车(使用 Lua 脚本)
func addToCartWithLua(cartID string, productID string, quantity int) {cartKey := "cart:" + cartID// Lua 脚本:增加购物车中商品的数量   luaScript := `local cartKey = KEYS[1]local productID = ARGV[1]local quantity = tonumber(ARGV[2])return redis.call('HINCRBY', cartKey, productID, quantity)`// 执行 Lua 脚本   _, err := rdb.Eval(ctx, luaScript, []string{cartKey}, productID, quantity).Result()if err != nil {log.Fatalf("Error executing Lua script: %v", err)}
}

相关文章:

redis基本数据结构-hash

这里写自定义目录标题 1. redis的数据结构hash1.1 Hash 数据结构的特点1.2 常见命令1.3 适用示例 2. 常见业务场景2.1 用户信息存储2.1.1 场景2.1.2 优势2.1.3 解决方案2.1.4 代码实现 2.2 购物车管理2.2.1 背景2.2.2 优势2.2.3 解决方案2.2.4 代码实现 3. 注意事项&#xff1a…...

21. 什么是MyBatis中的N+1问题?如何解决?

N1 问题是指在进行一对多查询时,应用程序首先执行一条查询语句获取结果集(即 1),然后针对每一条结果,再执行 N 条额外的查询语句以获取关联数据。这个问题通常出现在 ORM 框架(如 MyBatis 或 Hibernate&…...

天空卫士项目荣获“2024 IDC 中国20大杰出安全项目 ”奖项 ,实力见证安全守护

9月11日, IDC在上海圆满举办安全风险管控峰会,并现场官宣“2024 IDC中国20大杰出安全项目(CSO20) ”和“2024 IDC中国 CSO名人堂 (十大人物) ” 奖项名单。联通软研院申报的联通邮件系统安全合规建设项目被评为“2024 IDC中国20大杰出安全项目(CSO20) ”…...

Android生成Java AIDL

AIDL:Android Interface Definition Language AIDL是为了实现进程间通信而设计的Android接口语言 Android进程间通信有多种方式,Binder机制是其中最常见的一种 AIDL的本质就是基于对Binder的运用从而实现进程间通信 这篇博文从实战出发,用一个尽可能…...

嵌入式数据库sqlite和rocksdb的介绍以及对比

SQLite 和 RocksDB 都是非常流行的嵌入式数据库系统,但它们的设计理念和应用场景有所不同。下面是对这两个数据库系统的详细介绍以及它们之间的主要区别。 SQLite 简介 SQLite 是一个轻量级的关系数据库管理系统,完全由 C 语言编写而成。它以单一文件…...

数据结构之抽象数据类型(c语言版)

抽象数据类型的定义格式如下&#xff1a; ADT 抽象数据类型名{数据对象&#xff1a;<数据对象的定义>数据关系&#xff1a;<数据关系的定义>基本操作&#xff1a;<基本操作的定义> }ADT 抽象数据类型名 下面以复数为例给出完整的抽象数据类型的定义 ADT C…...

《ChatTTS一键安装详细教程》

ChatTTS 属于一种依托深度学习的文本转语音技术&#xff0c;能够把文本内容转换成自然且流畅&#xff0c;宛如真人发声的语音。ChatTTS 可以更出色地领会&#xff0c;理解文本所蕴含的情感、语调和语义&#xff0c;进而在语音输出时展现出更为精准和鲜活的各种情感。借助对大规…...

物联网之ESP32配网方式、蓝牙、WiFi

MENU 前言SmartConfig(智能配网)AP模式(Access Point模式)蓝牙配网Web Server模式WPS配网(Wi-Fi Protected Setup)Provisioning(配网服务)静态配置(硬编码)总结 前言 ESP32配网(Wi-Fi配置)的方式有多种&#xff0c;每种方式都有各自的优缺点。 根据具体项目需求&#xff0c;可以…...

golang 字符串浅析

go的字符串是只读的 测试源代码 package mainimport ("fmt""unsafe" )func swap(x, y string) (string, string) {return y, x }func print_string(obj *string, msg string) {string_ptr : (*[2]uintptr)(unsafe.Pointer(obj))first_obj_addr : string_…...

jantic/DeOldify部署(图片上色)附带Dockerfile和镜像

1. 克隆代码到DeOldify git clone https://github.com/jantic/DeOldify.git DeOldifyDeOldify源码 2. 安装依赖 这里会安装python以及创建deoldify环境 cd DeOldify conda env create -f environment.yml(base) rootDESKTOP-1FOD6A8:~/DeOldify# conda env create -f environm…...

2024年9月9日--9月15日(freex源码抄写+ue5肉鸽视频一节调节)

现在以工作为中心&#xff0c;其他可以不做硬性要求。周一到周四&#xff0c;晚上每天300行freex源码抄写&#xff0c;周六日每天1000行。每周3200行&#xff0c;每天完成该完成的即可&#xff0c;早上有时间时进行一小节独立游戏相关的视频教程作为调节即可&#xff0c;不影响…...

CLIP官方github代码详解

系列文章目录 文章目录 系列文章目录一、Usage1、conda install --yes -c pytorch pytorch1.7.1 torchvision cudatoolkit11.02、代码3、 二、1、2、3、 三、1、2、3、 四、1、2、3、 五、1、2、3、 六、1、2、3、 七、1、2、3、 八、1、2、3、 一、Usage 1、conda install --…...

ElementUI 布局——行与列的灵活运用

ElementUI 布局——行与列的灵活运用 一 . 使用 Layout 组件1.1 注册路由1.2 使用 Layout 组件 二 . 行属性2.1 栅格的间隔2.2 自定义元素标签 三 . 列属性3.1 列的偏移3.2 列的移动 在现代网页设计中&#xff0c;布局是构建用户界面的基石。Element UI 框架通过其强大的 <e…...

Docker快速部署Apache Guacamole

Docker快速部署Apache Guacamole ,实现远程访问 git clone "https://github.com/boschkundendienst/guacamole-docker-compose.git" cd guacamole-docker-compose ./prepare.sh docker-compose up -dhttps://IP地址:8443/ 用户名:guacadmin 密码:guacadmin docker …...

C++学习笔记----7、使用类与对象获得高性能(一)---- 书写类(1)

1、表格处理程序示例 表格处理程序是一个二维的“细胞”网格&#xff0c;每个格子包含了一个数字或者字符串。专业的表格处理程序比如微软的Excel提供了执行数学运算的能力&#xff0c;比如计算格子中的值的和。表格处理程序示例无意挑战微软的市场地位&#xff0c;但是对于演示…...

es6中set和map的区别

在ES6&#xff08;ECMAScript 2015&#xff09;中&#xff0c;Set 和 Map 是两种新的集合类型&#xff0c;它们提供了更高级的数据结构来存储唯一值或键值对集合。尽管它们在功能上有些相似&#xff0c;但它们在用途和内部机制上存在一些关键区别。 1. 基本概念 Set&#xff1…...

高级实时通信:基于 Python 的 WebSocket 实现与异步推送解决方案

高级实时通信&#xff1a;基于 Python 的 WebSocket 实现与异步推送解决方案 目录 &#x1f7e2; WebSocket 协议概述&#x1f535; 在 FastAPI 中实现 WebSocket&#x1f7e3; Django Channels 实现异步实时通信&#x1f534; 使用 Redis 实现实时推送 &#x1f7e2; 1. WebS…...

大二上学期详细学习计划

本学习完成目标&#xff1a; 项目&#xff1a; 书籍&#xff1a;《mysql必知必会》《java核心技术卷》&#xff08;暂时&#xff09;加强JavaSE的学习&#xff0c;掌握Java核心Mysqlsql&#xff08;把牛客上的那50道sql语句题写完&#xff09;gitmaven完成springboot项目&…...

Kafka【十四】生产者发送消息时的消息分区策略

【1】分区策略 Kafka中Topic是对数据逻辑上的分类&#xff0c;而Partition才是数据真正存储的物理位置。所以在生产数据时&#xff0c;如果只是指定Topic的名称&#xff0c;其实Kafka是不知道将数据发送到哪一个Broker节点的。我们可以在构建数据传递Topic参数的同时&#xff…...

SQL优化:执行计划详细分析

视频讲解&#xff1a;SQL优化&#xff1a;SQL执行计划详细分析_哔哩哔哩_bilibili 1.1 执行计划详解 id select_type table partitions type possible_keys key key_len ref rows filtered Extra 1.1.1 ID 【概…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度​

一、引言&#xff1a;多云环境的技术复杂性本质​​ 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时&#xff0c;​​基础设施的技术债呈现指数级积累​​。网络连接、身份认证、成本管理这三大核心挑战相互嵌套&#xff1a;跨云网络构建数据…...

Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器

第一章 引言&#xff1a;语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域&#xff0c;文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量&#xff0c;支撑着搜索引擎、推荐系统、…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…...

python报错No module named ‘tensorflow.keras‘

是由于不同版本的tensorflow下的keras所在的路径不同&#xff0c;结合所安装的tensorflow的目录结构修改from语句即可。 原语句&#xff1a; from tensorflow.keras.layers import Conv1D, MaxPooling1D, LSTM, Dense 修改后&#xff1a; from tensorflow.python.keras.lay…...

JS设计模式(4):观察者模式

JS设计模式(4):观察者模式 一、引入 在开发中&#xff0c;我们经常会遇到这样的场景&#xff1a;一个对象的状态变化需要自动通知其他对象&#xff0c;比如&#xff1a; 电商平台中&#xff0c;商品库存变化时需要通知所有订阅该商品的用户&#xff1b;新闻网站中&#xff0…...

libfmt: 现代C++的格式化工具库介绍与酷炫功能

libfmt: 现代C的格式化工具库介绍与酷炫功能 libfmt 是一个开源的C格式化库&#xff0c;提供了高效、安全的文本格式化功能&#xff0c;是C20中引入的std::format的基础实现。它比传统的printf和iostream更安全、更灵活、性能更好。 基本介绍 主要特点 类型安全&#xff1a…...

跨平台商品数据接口的标准化与规范化发展路径:淘宝京东拼多多的最新实践

在电商行业蓬勃发展的当下&#xff0c;多平台运营已成为众多商家的必然选择。然而&#xff0c;不同电商平台在商品数据接口方面存在差异&#xff0c;导致商家在跨平台运营时面临诸多挑战&#xff0c;如数据对接困难、运营效率低下、用户体验不一致等。跨平台商品数据接口的标准…...

13.10 LangGraph多轮对话系统实战:Ollama私有部署+情感识别优化全解析

LangGraph多轮对话系统实战:Ollama私有部署+情感识别优化全解析 LanguageMentor 对话式训练系统架构与实现 关键词:多轮对话系统设计、场景化提示工程、情感识别优化、LangGraph 状态管理、Ollama 私有化部署 1. 对话训练系统技术架构 采用四层架构实现高扩展性的对话训练…...

统计按位或能得到最大值的子集数目

我们先来看题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;请你找出 nums 子集 按位或 可能得到的 最大值 &#xff0c;并返回按位或能得到最大值的 不同非空子集的数目 。 如果数组 a 可以由数组 b 删除一些元素&#xff08;或不删除&#xff09;得到&#xff0c;…...

安宝特案例丨寻医不再长途跋涉?Vuzix再次以AR技术智能驱动远程医疗

加拿大领先科技公司TeleVU基于Vuzix智能眼镜打造远程医疗生态系统&#xff0c;彻底革新患者护理模式。 安宝特合作伙伴TeleVU成立30余年&#xff0c;沉淀医疗技术、计算机科学与人工智能经验&#xff0c;聚焦医疗保健领域&#xff0c;提供AR、AI、IoT解决方案。 该方案使医疗…...