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. JAVA中解决Filter过滤掉css,js,图片文件等问题

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOE ...

  2. RSA加密及加签

    1.对方要求我们的私钥是pkcs8格式,但是实际的公钥没有用pkcs8转换之后的私钥完成,所以是可以不是pkcs8的格式的.我们加签跟格式没有关系. 2.数据格式很重要,to_mpint而非crypt ...

  3. c++ 生成dll文件并调用-转

    .h(头文件) .lib(库文件) .dll(动态链接库文件) 之间的关系和作用的区分   .h头文件是编译时必须的,lib是链接时需要的,dll是运行时需要的. 附加依赖项的是.lib不是.dll, ...

  4. Spring Boot 常见标签

    @Controller(value=“名字”,descripation="描述",tags="具体" ) @RestController控制器(path=&qu ...

  5. 解决启动vs2010 未能找到自动配置的设置文件

    今天室友把固态拆掉,重新安上.打开vs2010出现 打开项目,出现 找了许多方法都无效. 发现c:user\Administer\documents\下,vs2010 .vs webset 那些文件点 ...

  6. sql语言 含有包含关系的查询 (含mysql 和sql sever)

    一.sql中查询包含关系的查询 sql语句中包含关系可以使用 in 和exist,但有些时候仅仅用这两个是不够的,还有表示方法是  not exist(b expect a )可以表示a包含b. 二. ...

  7. JavaEE思维导图

  8. session and cooike

    一.理解Cookie Cooie的作用: 当一个用户通过HTTP访问一个服务器时,这个服务器会将一些Key/Value键值对返回给客户端浏览器,并给这些数据加上一些限制条件,在条件符合时这个用户下次访 ...

  9. Oracle数据库-sqlplus命令下出现SP2-0640: Not connected

    可以正常登录sqlplus,通过sys as sysdba 但在sql>输入语句,反馈如下 解决方法: sql>输入conn sys/as sysdba Enter password: c ...

  10. python: ImportError:DLL load failed 解决方法。

    在学习使用wordcloud 库创建词云过程中,mooc里提到可以使用另一个库函数,来创建不同形状的词云. 就是这句: ... from scipy.misc import imread mk = i ...