深入浅出Redis(十二):Redis的排序命令Sort

引言

Redis是一款快速、优秀的键值对数据库,提供丰富的数据结构能在各种场景下实现功能,同时也提供丰富的命令来完成各种各样的功能,本篇文章将深入浅出的解析Sort命令的原理以及使用

原理

Sort 命令用来对list、set、zset对象进行排序,返回排序后的结果

Sort命令会使用一个与原来对象等长的数组,数组中的节点RedisSortObject存储了元素(指向对应元素)以及权值,排序就是根据权值来排序,权值默认情况下是浮点型,如果要排序的是字符串则权值为字符串对象

等长数组中的RedisSortObject节点会与排序对象中的元素一一对应记录元素对象的地址和权值

image.png

再使用快速排序根据等长数组中RedisSortObject对象中的权值进行排序(默认升序)

image.png

注意:排序只在新数组中操作,并没有改变原来的对象

图中排序流程对应以下命令操作

 127.0.0.1:6379> lpush number 1 3 5(integer) 3127.0.0.1:6379> lrange number 0 -11) "5"2) "3"3) "1"127.0.0.1:6379> sort number1) "1"2) "3"3) "5"

alpha 选项

alpha选项对字符串进行排序,如果对字符串进行排序不使用alpha会报出字符串无法转换为浮点型(默认浮点型)的异常

使用alpha选项则是对字符串进行排序

 127.0.0.1:6379> sadd set z x c n r a(integer) 6127.0.0.1:6379> smembers set1) "x"2) "n"3) "a"4) "r"5) "z"6) "c"127.0.0.1:6379> sort set alpha1) "a"2) "c"3) "n"4) "r"5) "x"6) "z"

by 选项

如果希望不是根据当前集合的元素进行排序,而是根据其他Key来排序则使用 by 选项

by *-value表示获取当前元素的key代替*-value拼接得到新的Key,查询新Key得到的值拿来排序

这种情况下RedisSortObject中记录的权值为新Key的值

比如当前元素是cc 则新key为 cc-value ,查询到新key值为88 因此排中间

如果新key结果为字符串 则要使用alpha 选项

 127.0.0.1:6379> sadd set tom cc jack(integer) 3127.0.0.1:6379> mset tom-value 99 cc-value 88 jack-value 77OK127.0.0.1:6379> smembers set1) "cc"2) "jack"3) "tom"127.0.0.1:6379> sort set by *-value1) "jack"2) "cc"3) "tom"#使用新key的值为字符串时使用alpha127.0.0.1:6379> mset tom-str a cc-str b jack-str cOK127.0.0.1:6379> sort set alpha by *-str1) "tom"2) "cc"3) "jack"

limit 选项

limit用来限制返回的数量,使用方式类比MySQL的limit

 127.0.0.1:6379> sort set alpha by *-str1) "tom"2) "cc"3) "jack"127.0.0.1:6379> sort set alpha by *-str limit 0 21) "tom"2) "cc"127.0.0.1:6379> sort set alpha by *-str limit 1 21) "cc"2) "jack"

get 选项

与by类似,但是by作用的是排序值,而get作用的是返回值

如果希望返回值不是当前元素的值,而是其他key的返回值,则使用get

get *-res表示获取当前元素的key代替*-res拼接得到新的Key,查询新Key得到的值用于返回结果

比如当前元素是cc 则新key为 cc-res ,查询到新key值为cc-result 因此响应时返回cc-result

 127.0.0.1:6379> sort set alpha by *-str limit 0 31) "tom"2) "cc"3) "jack"127.0.0.1:6379> mset tom-res tom-result cc-res cc-result jack-res jack-resultOK127.0.0.1:6379> sort set alpha by *-str limit 0 3 get *-res1) "tom-result"2) "cc-result"3) "jack-result"

store 选项

sort不是对原本的对象在原地进行排序,而是使用新数组来保存排序结果

使用store选项能将排序结果,使用list命令来生成Key,key为list类型

 127.0.0.1:6379> sort set alpha by *-str limit 0 3 get *-res1) "tom-result"2) "cc-result"3) "jack-result"127.0.0.1:6379> sort set alpha by *-str limit 0 3 get *-res store setresult(integer) 3127.0.0.1:6379> type setresultlist127.0.0.1:6379> lrange setresult 0 -11) "tom-result"2) "cc-result"3) "jack-result"

总结

本篇文章围绕Sort命令,深入浅出的解析Sort命令原理以及使用

Sort命令使用新的等长数组来对list、set、zset对象进行排序,其中数组中的节点RedisSortObject存储元素地址和权值,先使用节点记录要排序对象中元素的地址和权值,再使用快速排序根据权值进行排序然后返回

默认情况下权值为浮点型,如果是对字符串类型排序,需要使用alpha选项;想要使用其他key作为权值排序时使用by选项;限制结果集返回使用limit;想要返回其他key的值时使用get选项;想存储结果并生成列表对象时使用store

最后(一键三连求求拉~)

本篇文章笔记以及案例被收入 gitee-StudyJava、 github-StudyJava 感兴趣的同学可以stat下持续关注喔~

有什么问题可以在评论区交流,如果觉得菜菜写的不错,可以点赞、关注、收藏支持一下~

关注菜菜,分享更多干货,公众号:菜菜的后端私房菜

本文由博客一文多发平台 OpenWrite 发布!

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

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

相关文章

JavaEE实验三:3.5学生信息查询系统(动态Sql)

题目要求: 使用动态SQL进行条件查询、更新以及复杂查询操作。本实验要求利用本章所学知识完成一个学生信息系统,该系统要求实现3个以下功能: 1、多条件查询: 当用户输入的学生姓名不为空,则根据学生姓名进行学生信息的查询; 当用户…

Day:006(1) | Python爬虫:高效数据抓取的编程技术(爬虫工具)

selenium介绍与安装 Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium 可以直接运行在浏览器上,它支持所有主流的浏览器&am…

C++11 设计模式1. 模板方法(Template Method)模式学习。UML图

一 什么是 "模板方法(Template Method)模式" 在固定步骤确定的情况下,通过多态机制在多个子类中对每个步骤的细节进行差异化实现,这就是模板方法模式能够达到的效果。 模板方法模式属于:行为型模式。 二 &…

2024-4-10-day13-实战:商城首页(上)

个人主页:学习前端的小z 个人专栏:HTML5和CSS3悦读 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结,欢迎大家在评论区交流讨论! 文章目录 ✍作业 ✍作业 .bg-backward {width: 60px; height: 60px;background: url(..…

Unity 通过权重做随机

我们可以通过Random.Range方法结合权重来实现随机选择。具体步骤如下: 首先,创建一个数组,其中包含你要选择的项目,并为每个项目分配一个权重值。 计算所有权重值的总和。 使用Random.Range生成一个介于0和总权重之间的随机数。…

常见分类算法

一、ChatGPT 在人工智能和机器学习领域,分类算法是一种监督学习技术,用来识别输入数据所属的类别。以下是一些常见的分类算法: 1. 决策树(Decision Trees): 决策树通过创建一系列的问题或决策,来将数据…

让我看看谁还在用conda?

目录 前言下载方式安装命令使用方式及小技巧一些常用的命令安装软件小技巧一些关于conda环境的建议 最后 前言 相信大家在用conda的时候都遇到过各种各样的问题吧,比如创建环境非常缓慢、安装软件并解析依赖的速度非常感人等,有时候等待半小时甚至更久最…

mysql查询某条记录所在的行号

有时候我们想知道某条记录在表中的多少行,这样我们就可以开始继续上一次的任务了。 下面是SQL,可以直接执行,把表名改成自己真实的表名就好了,还得注意下子查询的排序,也得按自己真实需求来即可: SET row…

Mongodb入门--头歌实验MongoDB数据库安全

MongoDB 默认的启动是不验证用户名和密码的,启动 MongoDB 服务后,可以直接用命令 mongo 连接上来,对所有的库具有 root 权限。 这种情况下数据就像在“裸奔”一样,任何人都能修改我们的数据,所以我们要添加一些限制&a…

小样本计数网络FamNet(Learning To Count Everything)

小样本计数网络FamNet(Learning To Count Everything) 大多数计数方法都仅仅针对一类特定的物体,如人群计数、汽车计数、动物计数等。一些方法可以进行多类物体的计数,但是training set中的类别和test set中的类别必须是相同的。 为了增加计数方法的可拓…

构建你的第一个知识图谱项目:从零开始

构建你的第一个知识图谱项目:从零开始 引言 在数据驱动的世界中,知识图谱不仅仅是一个概念上的创新,它已经成为了连接复杂信息、提供深入见解的强大工具。无论您是数据科学家、软件开发人员还是业务分析师,构建知识图谱可以帮助您…

二百三十、MySQL——MySQL表的索引

1 目的 梳理一下目前MySQL维度表的索引情况,当然网上也有其他博客专门讲MySQL索引的,我这边只是梳理一下目前的索引状况而已 2单列索引 2.1 索引截图 2.2 建表语句 3 联合索引 3.1 索引截图 3.2 建表语句 4 参考的优秀博客 http://t.csdnimg.cn/ZF7…

Ubuntu Desktop:创建桌面启动图标

Ubuntu Desktop:创建桌面启动图标 在Ubuntu Desktop上创建桌面启动图标是一个相对简单的过程,可以帮助用户快速访问他们最常用的应用程序。本文旨在指导你完成创建一个桌面启动图标的步骤,从而使你能够轻松启动你的应用程序。 为什么创建桌…

网络IO模型以及实际应用

网络IO模型 本文主要介绍了几种不同的网络IO模型,以及实际应用中使用到的Reactor模型等。 我们常说的网络IO模型,主要包含阻塞IO、非阻塞IO、多路复用IO、信号驱动IO、异步IO。 根据第一个阶段:是否需要阻塞,分为阻塞和非阻塞IO。…

Linux双网卡默认路由优先级设置不正确,导致网络不通问题定位

问题描述 RHEL9 双网卡环境,两个网卡配置如下:(eth0 走内网,eth1 走外网) eth0 192.168.10.20/24 网关: 192.168.10.254 eth1 10.206.216.92/24 网关: 10.206.216.254配置完成后,curl https://www.baidu.com访问百度失…

国税发票查验接口、电子增值税发票查验接口、数电票查验接口

翔云发票查验接口支持增值税发票管理系统开具发票的真伪,通过发票代码、号码、日期、金额、校验码四要素信息进行真伪的查验,支持返回全票面信息,API接口便于集成,可适用于多种应用场景。 发票查验接口python调用示例:…

外包干了17天,技术倒退明显

先说情况,大专毕业,18年通过校招进入湖南某软件公司,干了接近6年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落! 而我已经在一个企业干了四年的功能…

web自动化测试系列-selenium xpath定位方法详解(六)

1.xpath介绍 XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航。而html中也应用了这种语言 ,所以 ,我们定位html页面元素时也会用到xpath这种方法 。 2.xpath定位方式 xpath主要通过以下四种方法定位 &#…

白帽工具箱:Metasploit框架中的db_nmap扫描艺术

🌟🌌 欢迎来到知识与创意的殿堂 — 远见阁小民的世界!🚀 🌟🧭 在这里,我们一起探索技术的奥秘,一起在知识的海洋中遨游。 🌟🧭 在这里,每个错误都…

有趣的css - 太极八卦图

大家好,我是 Just,这里是「设计师工作日常」,今天分享的是用css 实现一个动态的太极八卦图。 《有趣的css》系列最新实例通过公众号「设计师工作日常」发布。 目录 整体效果核心代码html 代码css 部分代码 完整代码如下html 页面css 样式页面…