Rust开发——使用rust实现Redis中hset
一、Redis中hset
HSET 是 Redis 中用于在哈希数据结构中设置指定字段的值的命令。哈希是一种类似于字典或映射的数据结构,它存储了键值对的集合,其中每个键都包含多个字段和与这些字段相关联的值。
哈希表在 Redis 中以键值对形式存储,并通过唯一的键名来访问。每个键都可以关联多个字段和对应的值,这使得哈希表非常适合存储对象、实体或记录的属性。
HSET 命令的基本语法是:
HSET key field value
key是哈希表的名称。field是要设置值的字段名称。value是要存储在字段中的值。
举例来说,假设我们有一个用户信息的哈希表,键为 user:1001,我们可以使用 HSET 命令来设置用户ID为 1001 的用户名为 johndoe:
HSET user:1001 username johndoe
这个命令将在 user:1001 哈希表中的 username 字段设置值为 johndoe。之后,可以使用 HGET 命令来获取指定字段的值:
HGET user:1001 username
以上命令将返回 user:1001 哈希表中 username 字段的值,即 johndoe。
哈希表的优势在于可以高效地存储和检索大量的字段-值对,特别适用于需要存储和查询对象属性的场景。除了 HSET 命令之外,Redis 还提供了其他与哈希表操作相关的命令,如 HGETALL 用于获取哈希表中所有字段和值的列表,HDEL 用于删除一个或多个字段等等。
二、Hset的应用
HSET 命令在 Redis 中有许多应用场景,特别是在需要存储和检索对象属性的情况下非常有用。以下是一些 HSET 命令在实际应用中的常见用例:
1. 存储用户信息
用于存储用户信息是 HSET 命令的常见用例之一。例如,存储用户的用户名、电子邮件、年龄等信息:
HSET user:1001 username johndoe
HSET user:1001 email john@example.com
HSET user:1001 age 30
2. 缓存对象属性
在缓存中存储对象属性是提高读取性能的一种方式。比如,存储商品信息:
HSET product:5001 name "Product Name"
HSET product:5001 price 29.99
HSET product:5001 category "Electronics"
3. 记录实时数据
用于记录实时数据的情况,例如实时监控系统中的指标数据:
HSET stats:today visits 1000
HSET stats:today purchases 50
HSET stats:today revenue 2500.00
4. 缓存对象状态
在缓存中存储对象状态或配置信息:
HSET server:status hostname "Server-A"
HSET server:status status "Running"
HSET server:status users_connected 50
5. 存储表单数据
在 Web 开发中,可以使用哈希表存储表单数据,比如用户提交的表单信息:
HSET form:submission:1001 name "Alice"
HSET form:submission:1001 email "alice@example.com"
HSET form:submission:1001 message "This is a sample message."
6. 对象属性索引
用于创建对象属性的索引,以便于检索和查询。例如,在数据库中存储用户的兴趣标签:
HSET interest:books user:1001 1
HSET interest:music user:1001 1
HSET interest:travel user:1001 1
哈希数据结构提供了灵活性和高效性,能够存储和管理多个字段和值,因此在许多需要键值对集合的场景中被广泛应用。
三、使用Rust实现Hset表
在Rust中,是没有Hset这具库API,如果想实现像Redis中hset,要自己动手实现,这里我想的实现的结构是记录一篇文章的评论,评论的ID,与回复评论的内容与ID,存储内容如下表:

实现代码:
use std::{collections::HashMap, borrow::Borrow};
use std::hash::Hash;#[derive(Clone)]
pub struct Value<K,V>
{pub value : HashMap<K,V>,
}impl <K,V> Value<K,V>
{pub fn new() ->Self{Self { value: HashMap::new()}}
}#[derive(Clone)]
pub struct Field<K,V>
{pub field : Value<K,V>,pub ex_field : HashMap<K,Value<K,V>>,
}impl<K,V> Field<K,V>
{pub fn new() ->Self{Self { field: Value::new(), ex_field: HashMap::new()}}
}#[derive(Clone,Default)]
pub struct HashSet<K,V>
{pub set : HashMap<K,Field<K,V>>,
}impl<K,V> HashSet<K,V>
where
K:Hash + Eq,
V:Copy,
{pub fn new() ->Self{Self { set: HashMap::new()}}pub fn insert(&mut self, key : K, field : K, value : V,sub_field : Option<K>) ->bool{match sub_field{Some(ex_key) =>{match self.set.get_mut(&key){Some(f_value) =>{match f_value.ex_field.get_mut(&ex_key){Some(ex_value) =>{match ex_value.value.get_mut(&field){Some(_ex) => false,None =>{ex_value.value.insert(field, value);true},}},None =>{let mut sub : Value<K,V> = Value::new();sub.value.insert(field, value);f_value.ex_field.insert(ex_key,sub);true},}},None =>{let mut sub : Value<K,V> = Value::new();sub.value.insert(field, value);let mut m_field : Field<K,V> = Field::new();m_field.ex_field.insert(ex_key, sub);self.set.insert(key, m_field);true},}},None =>{match self.set.get_mut(&key){Some(set) =>{match set.field.value.get_mut(&field){Some(_v) => false,None =>{set.field.value.insert(field, value);true}}},None =>{let mut m_field : Field<K,V> = Field::new();m_field.field.value.insert(field, value);self.set.insert(key, m_field);true}}},}}pub fn remove(&mut self, key : K , field : K, sub_field : Option<K>)->bool{match sub_field{Some(ex_key) =>{match self.set.get_mut(&key){Some(f_value) =>{match f_value.ex_field.get_mut(&ex_key){Some(ex_value) =>{match ex_value.value.get_mut(&field){Some(_ex) =>{ex_value.value.remove(&field);true}None => false,}},None => false}},None => false}},None =>{match self.set.get_mut(&key){Some(set) =>{match set.field.value.get_mut(&field){Some(_v) =>{set.field.value.remove(&field);true},None => false}},None =>false}},}}pub fn get_field_value(&self,key : K, field : K) -> Result<V,bool>{match self.set.get(&key){Some(value) =>{match value.field.value.get(&field){Some(v) => Ok(*v),None => Err(false),}},None => Err(false)}}pub fn get_ex_field_value(&self,key:K, field : K,sub_field : K) ->Result<V,bool>{match self.set.get(&key){Some(value) =>{match value.ex_field.get(&sub_field) {Some(sub_value) =>{match sub_value.value.get(&field){Some(v) => Ok(*v),None => Err(false),}}None => Err(false)}}None => Err(false)}}
}pub fn hset_size(hset : HashSet<&str,u64>) ->usize
{let mut size : usize = 0;for (k,v) in hset.set{let f_size = field_size(v);size += k.len() + f_size;}size
}pub fn field_size(field : Field<&str,u64>) -> usize
{let mut f_size : usize = 0;for(m_k,_m_v) in field.field.value{f_size += m_k.len() + 8;}let mut ex_size : usize = 0;for(f_k,f_v) in field.ex_field{let mut sub_size : usize = 0;for (s_k, _s_v) in f_v.value.iter(){sub_size += s_k.len() + 8;}ex_size += sub_size + f_k.len();}f_size + ex_size
}
use core::num;
use std::{mem, collections::{HashMap}, time::{SystemTime, UNIX_EPOCH}, borrow::{Borrow, BorrowMut}, cell::RefCell};pub struct CanisterState
{data : HashSet<String,u64>,
}fn main()
{let v : Vec<u8> = vec![65];let m = String::from_utf8(v.clone()).unwrap();print!("{}\n",m);LIKES.with(|like_ref|{let hset : CanisterState = CanisterState { data: mem::take(&mut like_ref.borrow_mut()) };});let mut hset : HashSet<&str,u64> = HashSet::new();hset.insert("唐诗", "王维",time(),Some("10"));hset.insert("唐", "李白",time(),None);hset.insert("诗", "李白",time(),None);hset.insert("宋", "李清照",time(),Some("1"));hset.insert("宋词", "李清照",time(),None);let r = hset.get_field_value("唐诗", "李白");match r{Ok(v) => print!("{}\n",v),Err(e) => print!("{}\n",e),}print!("{}\n",hset_size(hset.clone()));let _ = hset.remove("matt", "200", None);hset.insert("matt".to_string(), "300".to_string(),"200".to_string(),None);hset.insert("matt".to_string(), "200".to_string(),"200".to_string(),None);hset.insert("45m".to_string(), "300".to_string(),"200".to_string(),None);hset.insert("45m".to_string(), "200".to_string(),"200".to_string(),None);/show(hset.clone());
}相关文章:
Rust开发——使用rust实现Redis中hset
一、Redis中hset HSET 是 Redis 中用于在哈希数据结构中设置指定字段的值的命令。哈希是一种类似于字典或映射的数据结构,它存储了键值对的集合,其中每个键都包含多个字段和与这些字段相关联的值。 哈希表在 Redis 中以键值对形式存储,并通…...
海康Visionmaster-环境配置:VB.Net 二次开发环境配 置方法
Visual Basic 进行 VM 二次开发的环境配置分为三步。 第一步,使用 VS 新建一个框架为.NET Framework 4.6.1,平台去勾选首选 32 为的工程,重新生成解决方案,保证工程 Debug 下存在 exe 文件,最后关闭新建工程࿱…...
51单片机应用从零开始(四)
51单片机应用从零开始(一)-CSDN博客 51单片机应用从零开始(二)-CSDN博客 51单片机应用从零开始(三)-CSDN博客 详解 KEIL C51 软件的使用建立工程-CSDN博客 详解 KEIL C51 软件的使用设置工程编绎与连接程序…...
Django下的Race Condition漏洞
目录 环境搭建 无锁无事务的竞争攻击复现 无锁有事务的竞争攻击复现 悲观锁进行防御 乐观锁进行防御 环境搭建 首先我们安装源码包:GitHub - phith0n/race-condition-playground: Playground for Race Condition attack 然后将源码包上传到Ubuntu 为了方便使…...
【数据结构】希尔排序(最小增量排序)
👦个人主页:Weraphael ✍🏻作者简介:目前正在学习c和算法 ✈️专栏:数据结构 🐋 希望大家多多支持,咱一起进步!😁 如果文章有啥瑕疵 希望大佬指点一二 如果文章对你有帮助…...
Android Native崩溃信息分析和 工具(addr2line和ndkstack)使用
这里以一个实际的crash案例未demo进行分析和讲解。针对native的崩溃信息。一般来讲,较快的方式是直接检索到backtrace,然后通过分析和使用工具addr2line和 ndk-stack等定位到出问题的地方。这里截取了一段 崩溃日志,具体如下: 01…...
2023年05月 Python(六级)真题解析#中国电子学会#全国青少年软件编程等级考试
Python等级考试(1~6级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 明明每天坚持背英语单词,他建立了英语单词错题本文件“mistakes.txt”,将每天记错的单词增加到该文件中,下列打开文件的语句最合适的是?( ) A: f = open(“mistakes.txt”) B: …...
SQLite3 数据库学习(文章链接汇总)
参考引用 SQLite 权威指南(第二版)SQLite3 入门 SQLite3 数据库学习(一):数据库和 SQLite 基础 SQLite3 数据库学习(二):SQLite 中的 SQL 语句详解 SQLite3 数据库学习(三…...
【VSCode】Visual Studio Code 下载与安装教程
前言 Visual Studio Code(简称 VS Code)是一个轻量级的代码编辑器,适用于多种编程语言和开发环境。本文将介绍如何下载和安装 Visual Studio Code。 下载安装包 首先,我们需要从官方网站下载 Visual Studio Code 的安装包。请访…...
分布式教程从0到1【1】分布式基础
1 分布式基础概念 1.1 微服务 微服务架构风格,就像是把一个单独的应用程序开发为一套小服务,每个小服务运行在自己的进程中,并使用轻量级机制通信,通常是 HTTP API。这些服务围绕业务能力来构建,并通过完全自动化部署…...
Ubuntu22.04 部署Mqtt服务器
1、打开Download EMQX (www.emqx.io)下载mqtt服务器版本 2、Download the EMQX repository curl -s https://assets.emqx.com/scripts/install-emqx-deb.sh | sudo bash 3.Install EMQX sudo apt-get install emqx 4.Run EMQX sudo systemctl start…...
HMM与LTP词性标注之LTP介绍
文章目录 LTP 上图缺点:参数太多,中文语料库匮乏 注意力机制,相当于给每一个词赋予一个权重,权重越大的越重要。 bert的缺点:神经元太多,较慢。 LTP 如果只是需要做词性的识别,那么用LTP就可…...
基于SSM的学生疫情信息管理系统设计与实现
末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…...
分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测
分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测 目录 分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据…...
用电子签章软件怎么给标书一键签章的小故事
在这个数字化时代,电子签章已经成为了商务往来的重要一环。作为国内电子签章软件的佼佼者,微签凭借其19年的电子签研发应用经验,为中小企业提供了安全可靠的电子签章软件服务。 从审批场景到合同签署,微签都展现出卓越的电子签章…...
Windows10电脑没有微软商店的解决方法
在Windows10电脑中用户可以打开微软商店,下载自己需要的应用程序。但是,有用户反映自己Windows10电脑上没有微软商店,但是不清楚具体的解决方法,接下来小编给大家详细介绍关于解决Windows10电脑内微软商店不见了的方法,…...
SpringCloud-Gateway修改Response响应体,并解决大数据量返回不全等问题
官网相关案例: Spring Cloud Gatewayhttps://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#the-modifyresponsebody-gatewayfilter-factory ModifyRequestBodyGatewayFilterFactory类: https://github.com/spring-cloud/spring-cloud-gate…...
Spark与SQL之间NB的转换_withClumn,split及SubString
业务中有这样一个场景,我想实现的是将dataframe表table1中的字段b1与c1的内容使用下划线_连接起来列的名字为d1,比如比如学习_1,睡觉_2,吃饭_3,这是我的第一个需求;随后我想保留的是dataframe表table1中的字段d1中的数据比如学习_…...
修改服务器端Apache默认根目录
目标:修改默认Apache网站根目录 /var/www/html 一、找到 DocumentRoot “/var/www/html” 这一段 apache的根目录,把/var/www/html 这个目录改 #DocumentRoot "/var/www/html" DocumentRoot "/home/cloud/tuya_mini_h5/build" 二、…...
网络安全(大厂面试真题集)
前言 随着国家政策的扶持,网络安全行业也越来越为大众所熟知,想要进入到网络安全行业的人也越来越多。 为了拿到心仪的 Offer 之外,除了学好网络安全知识以外,还要应对好企业的面试。 作为一个安全老鸟,工作这么多年…...
用Python模拟10000次实验,直观理解卡方分布如何从正态分布‘长’出来
用Python模拟10000次实验,直观理解卡方分布如何从正态分布‘长’出来统计学中的分布概念常常让人望而生畏,尤其是当公式推导占据主导时。但如果我们换一种方式——用代码和可视化来探索,这些抽象概念会立刻变得鲜活起来。今天,我们…...
Flutter+React Native如何真正实现Lovable?跨端情感一致性开发规范(仅限内部团队流通版)
更多请点击: https://codechina.net 第一章:Lovable移动端应用开发 Lovable 是一套面向现代移动开发的轻量级跨平台框架,专为构建高响应、低资源占用且具备原生体验的应用而设计。它采用声明式 UI 编程模型,底层通过桥接机制与 i…...
【应用实战】基于Dify与多Agent的凭证与档案管理
一、智能文档处理:基于Dify与多Agent的凭证与档案管理革新 在金融行业,文档处理贯穿业务始终。传统的纯人工方式不仅耗时费力,而且极易出错。智能文档处理(Intelligent Document Processing, IDP)融合了OCR、自然语言处…...
鸿蒙今日穿搭页面构建:搭配推荐与风格筛选模块详解
鸿蒙今日穿搭页面构建:搭配推荐与风格筛选模块详解 前言 在 HarmonyOS 6.0 应用开发中,穿搭类页面的核心挑战在于如何展示搭配灵感、风格筛选和衣橱管理。本文将以“今日穿搭”应用的主页面为例,深入解析如何在鸿蒙平台上构建时尚穿搭类应用的…...
Unity Play Mode状态保存原理与实战配置指南
1. 为什么“Play Mode Save”不是个噱头,而是Unity开发者每天都在默默忍受的痛点你有没有过这样的经历:在Unity编辑器里调试一个带状态的敌人AI,刚给它加了血量、仇恨目标、技能冷却计时器,正准备按Play键验证行为逻辑——结果一按…...
门店数据采集如何做质量控制:LBS、图片质检、去重和人工复核
门店数据采集项目的难点,不是“采不到数据”,而是采回来的数据能不能被业务相信、被系统处理、被管理层复盘。质量控制通常要覆盖位置与时间校验、图片质量检测、图片去重、字段标准化和人工复核。一个全国项目可能涉及几百到几万家门店,图片…...
AI Agent游戏测试革命:自动生成10万+边界用例,覆盖率提升3.2倍——附可运行Python测试Agent源码
更多请点击: https://intelliparadigm.com 第一章:AI Agent游戏行业应用全景图 AI Agent 正在重塑游戏开发、运营与玩家体验的全生命周期。从智能NPC的行为建模,到自动化测试与关卡生成,再到实时个性化内容推荐与反作弊决策&…...
如何永久激活IDM?免费IDM激活脚本终极指南
如何永久激活IDM?免费IDM激活脚本终极指南 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script 还在为IDM试用期到期而烦恼吗?IDM Activation …...
达梦数据库-收缩数据库表空间步骤及示例记录总结
1达梦数据库-收缩数据库表空间步骤及示例记录总结 注:收缩表空间,如果空闲空间都在尾部,可以直接收缩成功,如果尾部不空闲,中部空闲,则需要移走使用尾部的表后再收缩,生产环境,如果…...
MoE混合专家架构:揭秘大模型参数激活率与真实算力开销
1. 这不是“参数越多越强”的简单故事:拆解大模型里那个被悄悄藏起来的“开关”你肯定见过这类标题:“GPT-4 参数高达1.8万亿!”、“DeepSeek-R1 拥有6710亿参数!”——光是数字本身就像一记重锤,砸得人头晕目眩。但真…...
