初识Redis · C++客户端set和zset

目录

前言:

set

sadd sismember smembers

spop scard

sinter sinterstore

zset

zadd zrange zcard

zrem zrank zscore


前言:

前文我们已经介绍了string list hash在Redis-plus-plus的使用,本文我们开始介绍set和zset在redis-plus-plus的使用。

本文作为Redis初阶的一个收尾,介绍完对应的使用之后,我们就可以进入到Redis的底层原理了。


set

sadd sismember smembers

对于sadd来说,它就是set add的意思嘛,在命令行中,我们可以直接sadd key v1 v2 v3,在这里,我们可以单次插入,也可以是初始化列表,也可以是迭代器,它的讨论和前面的list几乎是一样的。对于sismember来说,就是判断value是否在key里面,命令行的用法是sismember key member,这里其实用法也是,不过我们需要用bool类型接受而已。对于smembers来说,就是用来得到所有的member的,按照之前的套路,我们需要用一个迭代器来带出对应的member:

void test_1(Redis &redis)
{redis.flushall();redis.sadd("key","1");redis.sadd("key",{"2", "3"});std::vector<std::string> vec{"4","5"};redis.sadd("key",vec.begin(), vec.end());bool ans = redis.sismember("key", "3");if(ans) std::cout << "is member" << std::endl;else std::cout << "not member" << std::endl;auto iter = std::inserter(vec, vec.end());redis.smembers("key", iter);for(auto e : vec)std::cout << e << " ";std::cout << std::endl;}

spop scard

我们仍然要注意一个点是,set的删除是随即删除的,所以我们删除的时候是没有办法指定的,对于scard,它就是一个用来计数的,代码如下:

void test_2(Redis &redis)
{redis.flushall();redis.sadd("key","1");redis.sadd("key",{"2", "3"});auto ans = redis.spop("key");if(ans) std::cout << ans.value() << std::endl;else std::cout << "set is empty" << std::endl;long long res = redis.scard("key");std::cout << res << std::endl;}

sinter sinterstore

在命令行中,使用sinter是直接返回交集的结果,在redis-plus-plus中,我们可以将结果存储到一个容器里面,sinterstore是可以将结果存储到另一个key中,不过是存储的位置不同罢了。

void test_3(Redis &redis)
{redis.flushall();redis.sadd("key", "1");redis.sadd("key", {"2", "3"});redis.sadd("key1", {"1", "2", "4"});std::vector<std::string> vec;auto iter = std::back_inserter(vec);redis.sinter({"key", "key1"}, iter);for(auto e : vec)std::cout << e << " ";std::cout << std::endl;}

void test_4(Redis &redis)
{redis.flushall();redis.sadd("key", "1");redis.sadd("key", {"2", "3"});redis.sadd("key1", {"1", "2", "4"});long long n = redis.sinterstore("key2", {"key", "key1"});std::cout << n << std::endl;std::vector<std::string> vec;auto iter = std::back_inserter(vec);redis.smembers("key2", iter);for(auto e : vec)std::cout << e << " ";std::cout << std::endl;
}

对于set的交集并集差集都是一样的,所以这里我们就使用交集来介绍了,其他的两个我们完全可以依次类推。


zset

对于zset来说,相对就要麻烦一点,因为它的查询,就会带着两种风格进行查询,一种是带着score的,一种是不带着score的,并且因为分数的存在,就还可以引入排名,虽然是分数的附属品,但是也为zset的难度增加了一点。

zadd zrange zcard

void test_1(Redis &redis)
{redis.flushall();redis.zadd("key", "zhangsan",10);redis.zadd("key", {std::make_pair("wangwu",30),std::make_pair("lisi",20)});std::vector<std::pair<std::string, double>> vec{std::make_pair("zhaoliu",40),std::make_pair("tianqi",50)};redis.zadd("key", vec.begin(), vec.end());std::vector<std::pair<std::string, double>> ans;auto res = std::back_inserter(ans);redis.zrange("key", 0, -1, res);for(auto e : ans)std::cout << e.first  << ":" << e.second<< std::endl;std::cout << redis.zcard("key") << std::endl;
}

不过大家把这段代码放在自己的机器上跑可能会出问题,因为对于zrange来说,旧版本的redis是可以直接不用参数,直接带分数返回的,但是新版本的需要带上第五个参数true。

zrem zrank zscore

对于zrem来说,就是删除元素,不过它和set不同的是它可以指定元素删除,对于zrank就是返回排名,对于zscore来说就是返回对应的分数:

void test_2(Redis &redis)
{redis.flushall();redis.zadd("key", "zhangsan",10);redis.zadd("key", {std::make_pair("wangwu",30),std::make_pair("lisi",20)});redis.zrem("key", "zhangsan");long long n = redis.zcard("key");std::cout << n << std::endl;auto ans = redis.zscore("key", "lisi");if(ans) std::cout << ans.value() << std::endl;else std::cout << "not exist" << std::endl;auto res = redis.zrank("key", "lisi");if(res) std::cout << res.value() << std::endl;else std::cout << "not exist" << std::endl;
}

当然了,zset的操作远不止于此,不过很多类似的操作我们已经通过string list等其他介绍过了,比如zadd的NX和XX,我们自己清楚就行,用到的时候实在忘了,咱们再看也不迟~~

那么,基本的命令部分,我们就算是正式完结啦!

gogogo , 进入到原理部分咯~


感谢阅读!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/79982.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sed命令笔记250419

sed命令笔记250419 sed&#xff08;Stream Editor&#xff09;是 Linux/Unix 系统中强大的流编辑器&#xff0c;主要用于对文本进行过滤和转换&#xff08;按行处理&#xff09;。它支持正则表达式&#xff0c;适合处理文本替换、删除、插入等操作。以下是 sed 的详细解析&…

ubuntu-24.04.2-live-server-arm64基于cloud-init实现分区自动扩容(LVM分区模式)

1. 环境 虚拟机镜像ISO&#xff1a;ubuntu-24.04.2-live-server-arm64.iso 2. 定制cloud-init镜像 2.1 安装OS 基于ubuntu-24.04.2-live-server-arm64.iso&#xff0c;通过virt-manager安装操作系统&#xff0c;语言建议选择英文&#xff0c;分区选择基于LVM的自动分区&…

vue3专题1------父组件中更改子组件的属性

理解 Vue 3 中父组件如何引用子组件的属性是一个很重要的概念。 这里涉及到 defineExpose 和 ref 这两个关键点。 方法&#xff1a;使用 defineExpose 在子组件中暴露属性&#xff0c;然后在父组件中使用 ref 获取子组件实例并访问暴露的属性。 下面我将详细解释这个过程&…

数据仓库分层架构解析:从理论到实战的完整指南​​

数据仓库分层是构建高效数据体系的核心方法论。本文系统阐述ODS、DWD、DWS、ADS四层架构的设计原理&#xff0c;结合电商用户行为分析场景&#xff0c;详解各层功能及协作流程&#xff0c;并给出分层设计的原则与避坑指南&#xff0c;帮助读者掌握分层架构的落地方法。 一、为什…

从零搭建一套前端开发环境

一、基础环境搭建 1.NVM(Node Version Manager)安装 简介 nvm&#xff08;Node Version Manager&#xff09; 是一个用于管理多个 Node.js 版本的工具&#xff0c;允许开发者在同一台机器上轻松安装、切换和使用不同版本的 Node.js。它特别适合需要同时维护多个项目&#xff…

计算机组成原理笔记(十六)——4.1基本算术运算的实现

计算机中最基本的算术运算是加法运算&#xff0c;加、减、乘、除运算最终都可以归结为加法运算。 4.1.1加法器 一、加法器的基本单元 加法器的核心单元是 全加器&#xff08;Full Adder, FA&#xff09;&#xff0c;而所有加法器都由 半加器&#xff08;Half Adder, HA&…

利用Qt创建一个模拟问答系统

界面&#xff1a; 添加了聊天显示区域&#xff08;QTextEdit&#xff09; 添加了发送按钮和清空对话按钮 优化了布局和窗口大小添加了时间戳显示 2、功能&#xff1a; 支持实时对话可以清空对话历史 支持按回车发送消息 添加了简单的关键词匹配响应系统 交互体验&#x…

神经光子渲染:物理级真实感图像生成——从麦克斯韦方程到深度学习

一、技术背景与核心突破 2025年&#xff0c;神经光子渲染&#xff08;Photonic Neural Rendering, PNR&#xff09;技术通过物理光学方程与神经辐射场的深度融合&#xff0c;在AIGC检测工具&#xff08;如GPTDetector 5.0&#xff09;的识别准确率从98%降至12%。该技术突破性地…

Linux中手动安装7-Zip软件文档

7zip位于EPEL源中&#xff0c;如果服务器可以联网或者配置了本地EPEL源则可以直接安装 yum install p7zip p7zip-plugins -y对于无法联网且没有配置本地EPEL源的服务器&#xff0c;可以通过官网下载安装包后&#xff0c;上传至服务器&#xff0c;手动安装 ## 下载地址&#x…

[密码学基础]GM/T 0018-2023 密码设备应用接口规范深度解析:技术革新与开发者实践

GM/T 0018-2023 密码设备应用接口规范深度解析&#xff1a;技术革新与开发者实践 GM/T 0018-2023《密码设备应用接口规范》是中国密码行业的重要标准&#xff0c;于2023年12月4日发布&#xff0c;2024年6月1日正式实施&#xff0c;替代了2012年版标准。该标准旨在规范密码设备…

8.QT-按钮类控件|Push Button|Radio Button|Check Box|Tool Button(C++)

Push Button 使⽤ QPushButton 表⽰⼀个按钮.这也是当前我们最熟悉的⼀个控件了. QPushButton 继承⾃ QAbstractButton .这个类是⼀个抽象类.是其他按钮的⽗类 在Qt Designer中也能够看到这⾥的继承关系 属性说明text按钮中的⽂本icon按钮中的图标iconSize按钮中图标的尺⼨sh…

CFIS-YOLO:面向边缘设备的木材缺陷检测轻量级网络解析

论文地址:https://arxiv.org/pdf/2504.11305 目录 一、论文核心贡献 二、创新点详解 2.1 CARAFE动态上采样 工作原理 优势对比 2.2 C2f_FNB轻量模块 计算效率 2.3 Inner-SIoU损失函数 三、实验验证 3.1 消融实验 3.2 对比实验 四、应用部署 4.1 边缘设备部署流程…

BUUCTF PWN刷题笔记(1-9)

才知道&#xff0c;由于栈对齐&#xff0c;直接动调看栈估计会错&#xff0c;用cyclic看 1.test_your_nc NC连接一下&#xff0c;这个网站似乎直接访问是不中的&#xff0c;怀疑是没开启web的端口。NC链接输入cat flag就OK了&#xff0c;应该只是让我这样的小菜鸟培养自信用的…

C#处理网络传输中不完整的数据流

1、背景 在读取byte数组的场景&#xff08;例如&#xff1a;读取文件、网络传输数据&#xff09;中&#xff0c;特别是网络传输的场景中&#xff0c;非常有可能接收了不完整的byte数组&#xff0c;在将byte数组转换时&#xff0c;因字符的缺失/增多&#xff0c;转为乱码。如下…

PostgreSQL 用户资源管理

PostgreSQL 用户资源管理 PostgreSQL 提供了多种机制来管理和限制用户对数据库资源的使用&#xff0c;以下是全面的资源管理方法&#xff1a; 1 连接限制 1.1 限制最大连接数 -- 在 postgresql.conf 中设置 max_connections 100 -- 全局最大连接数-- 为特定用户设置连接限…

新书速览|OpenCV计算机视觉开发实践:基于Qt C++

《OpenCV计算机视觉开发实践:基于Qt C》 本书内容 OpenCV是计算机视觉领域的开发者必须掌握的技术。《OpenCV计算机视觉开发实践:基于Qt C》基于 OpenCV 4.10与Qt C进行编写&#xff0c;全面系统地介绍OpenCV的使用及实战案例&#xff0c;并配套提供全书示例源码、PPT课件与作…

【上位机——MFC】消息映射机制

消息映射机制 Window消息分类消息映射机制的使用代码示例 MFC框架利用消息映射机制把消息、命令与它们的处理函数映射起来。具体实现方法是在每个能接收和处理消息的类中&#xff0c;定义一个消息和消息函数指针对照表&#xff0c;即消息映射表。 在不重写WindowProc虚函数的大…

docker学习笔记2-最佳实践

一、在容器中启动mysql的最佳实践 &#xff08;一&#xff09;查找目录 1、mysql的配置文件路径 /etc/mysql/conf.d 2、mysql的数据目录 /var/lib/mysql 3、环境变量 4、端口 mysql的默认端口3306。 &#xff08;二&#xff09;启动命令 docker run -d -p 3306:3306 …

Vue3核心源码解析

/packages/complier-core 定位​​&#xff1a;​​编译时核心​​&#xff0c;处理 Vue 模板的编译逻辑。​​核心功能​​&#xff1a; ​​模板解析​​&#xff1a;将 .vue 文件的模板语法&#xff08;HTML-like&#xff09;解析为 ​​抽象语法树 (AST)​​。​​转换优化…

n8n 中文系列教程_05.如何在本机部署/安装 n8n(详细图文教程)

n8n 是一款强大的开源工作流自动化工具&#xff0c;可帮助你连接各类应用与服务&#xff0c;实现自动化任务。如果你想快速体验 n8n 的功能&#xff0c;本机部署是最简单的方式。本教程将手把手指导你在 Windows 或 MacOS 上通过 Docker 轻松安装和运行 n8n&#xff0c;无需服务…