1、sort

排序最常见的是sort命令,可以对列表或者有序集合排序,最简单的排序方式如下:

> lpush list
(integer)
> lpush list
(integer)
> lpush list
(integer)
> sort list
) "
) "
) "

该命令常与alpha、desc、limit等搭配使用。

2、BY参数

上述的使用方法比较简单,有时候无法满足人们的需求,以学生成绩为例,人们需要按照成绩,来排序,从而得到一个相应的学号的列表,这样比较复杂的排序使用上述的方法就不好操作了,因此需要用BY参数来操作。

首先准备一个学号的列表,且最终希望这个列表按照学生的成绩排列。

> lpush list
(integer) 

给每个学生设置成绩,键名为stuscore:学号

>
OK
>
OK
>
OK
>
OK
>
OK
>
OK
>
OK
>
OK
>  

比较容易看出,第一名是学号为555的学生,最后一名是学号为777的学生。

> sort list by stuscore:* desc
) "
) "
) "
) "
) "
) "
) "
) "
) "

可以看出,BY这个参数的实际作用是:将待排序列表中的每个键值带入到stuscore:*的*中,并对score:*进行排序,从而获得对应的学号列表。

若代入*的键值不存在,则默认为0

> del stuscore:
(integer)
> sort list by stuscore:* desc
) "
) "
) "
) "
) "
) "
) "
) "
) "

3、GET参数

获得到排序后的列表,可以通过这种形式获取对应学号的学生信息,如姓名。

设姓名的键名如:stuname:学号,则可以这样获取:

>  MR.zhang
OK
>  MR.wang
OK
>  MISS.li
OK
>  MISS.lin
OK
> sort list by stuscore:* desc get stuname:*
) (nil)
) (nil)
) "MR.zhang"
) (nil)
) "MISS.lin"
) "MR.wang"
) (nil)
) (nil)
) "MISS.li"

使用get #可以一并输出list中的值

> sort list by stuscore:* desc get stuname:* get #
 ) (nil)
 ) "
 ) (nil)
 ) "
 ) "MR.zhang"
 ) "
 ) (nil)
 ) "
 ) "MISS.lin"
) "
) "MISS.li"
) "
) "MR.wang"
) "
) (nil)
) "
) (nil)
) "

4、store参数

如果想要存储排序的结果,可以将结果存于列表中

> sort list by stuscore:* desc get stuname:* get # store sort.result
(integer)
> lrange sort.result  -
 ) ""
 ) "
 ) ""
 ) "
 ) "MR.zhang"
 ) "
 ) ""
 ) "
 ) "MISS.lin"
) "
) "MISS.li"
) "
) "MR.wang"
) "
) ""
) "
) ""
) "

5、性能优化

根据《redis入门指南》:

sort命令是redis一个很强大且复杂的命令,使用不好很容易成为性能瓶颈,故在开发的时候需要注意这么几点:

1)尽可能减少待排序的元素的数量

2)使用limit,值获取需要的数据

3)如果需要获取的数据量比较大,请用store保存

redis排序的更多相关文章

  1. 三.redis 排序

    本篇文章介绍下redis排序命令.redis支持对list,set和sorted set元素的排序.排序命令是sort 完整的命令格式如下: SORT key [BY pattern] [LIMIT ...

  2. laravel操作Redis排序/删除/列表/随机/Hash/集合等方法全解

    Song • 3563 次浏览 • 0 个回复 • 2017年10月简介 Redis模块负责与Redis数据库交互,并提供Redis的相关API支持: Redis模块提供redis与redis.con ...

  3. Redis - 排序

    SORT 命令格式 SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALP ...

  4. redis的sort排序

    Redis排序命令是sort,完整的命令格式如下:SORT key [BY pattern] [LIMIT start count] [GET pattern] [ASC|DESC] [ALPHA] ...

  5. 【转载】Redis sort 排序命令详解

    转载地址:http://www.jb51.net/article/69131.htm 本文介绍redis排序命令 redis支持对list,set,sorted set元素的排序 sort 排序命令格 ...

  6. 解决Redis Cluster模式下的排序问题

    通常的redis排序我们可以这么做: 比如按商品价格排序:sort goods_id_set by p_*_price 这样在非集群模式下是没问题的,但如果在集群模式下,就会报错: 说是在集群模式下不 ...

  7. Redis简介 Linux安装Redis Redis使用

    其他一些操作(包括 APPEND.GETRANGE.MSET 和 STRLENGTH 也可用于字符串.请参见http://doc.redisfans.com/string/index.html ) 使 ...

  8. Java连接Redis之redis的增删改查

    一.新建一个maven工程,工程可以以jar的形式或war都行,然后导入正确的依赖 <project xmlns="http://maven.apache.org/POM/4.0.0& ...

  9. Redis常用数据类型及使用场景

    Redis最为常用的数据类型 字符串(String) 字符串列表(list) 字符串集合(set) 哈希(hash) 有序的字符串集合(sorted set) String(字符串) 字符串是最基本的 ...

随机推荐

  1. Linux 搭建Hadoop集群 ----workcount案例

    在 Linux搭建集群---JDK配置 Linux搭建集群---SSH免密登陆 Linux搭建集群---集群搭建成功 的基础上实现workcount案例 注意 虚拟机三台启动集群(自己亲自搭建) 1. ...

  2. cocos-lua3.17 cocos studio lua动画使用

    这里只贴具体使用代码,资源请使用自己的. 这里的资源是cocos studio导出的lua文件,其中就有root和动画 function GameLayer:playLhAni() local ani ...

  3. 【原创】MIPS相关

    MIPS是单字长定点指令平均执行速度 Million Instructions Per Second的缩写. 路由器等嵌入式系统多采用MIPS和ARM两种指令架构,最近在研究路由器,借机总结一下基于M ...

  4. 剑指Offer 19. 顺时针打印矩阵 (其他)

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数 ...

  5. 王者荣耀交流协会第5次Scrum立会

    开会时间:2017年10月31日下午18:00-18:31  共计31分钟 开会地点:一食堂二楼靠近窗户倒数第四排 今日完成工作进度: 王超同学完成了将生成饼状图原型整合到程序中 立会内容: 添加了新 ...

  6. 创建Java多线程的两种方式和线程异常

    一.使用多线程的两种方法  使用多线程的两种方法有:继承Thread类和实现runable接口. 二.继承Thread类 来看一下thread类的源代码: class Thread implement ...

  7. highcharts 获取不到隐藏容器大小

    1.固定图表大小 2.图表容器div的resize(绑定一个始终显示的,可以影响所有图表的) 影响容器大小改变的: 窗口大小改变 侧边栏切换 滚动条切换

  8. Python全栈之路----数据类型—元组类型

    元组类型:有序,不可变的,又叫只读列表  names = ("alex","jack","eric") 1.元组本身不可变,但如果元组中有可 ...

  9. 《从Lucene到Elasticsearch:全文检索实战》学习笔记五

    今天我给大家讲讲tf-idf权重计算 tf-idf权重计算: tf-idf(中文词频-逆文档概率)是表示计算词项对于一个文档集或语料库中的一份文件的重要程度.词项的重要性随着它在文档中出现的次数成正比 ...

  10. NN 激活函数 待修改

    Softmax 函数/算法 https://www.zhihu.com/question/23765351 RELU 激活函数及其他相关的函数 http://blog.csdn.net/u013146 ...