SORT 命令格式

SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination]

基本用法

SORT 命令可以对列表类型、集合类型和有序集合类型键进行排序。

对列表排序:

127.0.0.1:6379> LPUSH list 2 0 1 6
(integer) 4
127.0.0.1:6379> SORT list
1) "0"
2) "1"
3) "2"
4) "6"

对集合排序:

127.0.0.1:6379> SADD set 4 3 9 9
(integer) 3
127.0.0.1:6379> SORT set
1) "3"
2) "4"
3) "9"

对有序集合排序(在对有序集合排序时会忽略元素的分数):

127.0.0.1:6379> ZADD sorted_set 50 2 40 3 20 1 60 5
(integer) 4
127.0.0.1:6379> SORT sorted_set
1) "1"
2) "2"
3) "3"
4) "5"

ALPHA 参数

通过 ALPHA 参数实现按照字段顺序排序非数字元素。

127.0.0.1:6379> RPUSH list r e d i s
(integer) 5
127.0.0.1:6379> SORT list
(error) ERR One or more scores can't be converted into double
127.0.0.1:6379> SORT list ALPHA
1) "d"
2) "e"
3) "i"
4) "r"
5) "s"

从上面的示例看,如果没有加 ALPHA 参数,SORT 命令会尝试将所有元素转换成双精度浮点数来比较,如果无法转换则会提示错误。

DESC 参数

DESC 参数可以实现将元素按照从大到小的顺序排序。

127.0.0.1:6379> LPUSH list 2 0 1 6
(integer) 4
127.0.0.1:6379> SORT list DESC
1) "6"
2) "2"
3) "1"
4) "0"

LIMIT 参数

SORT 命令还支持 LIMIT 参数来返回指定范围的结果。用户和 SQL 的语句一样,LIMIT offset count,表示跳过前 offset 个元素并获取之后的 count 个元素。

127.0.0.1:6379> LPUSH list 2 0 1 6
(integer) 4
127.0.0.1:6379> SORT list DESC LIMIT 1 2
1) "2"
2) "1"

BY 参数

很多情况下列表(或集合、有序集合)中存储的元素是对象的 ID,单纯对这些 ID 排序有时意义并不大。更多的时候我们需要根据 ID 对应的对象的某个属性进行排序。比如要以商品的价格为依据对商品进行排序,则需要使用 SORT 命令的 BY 参数。BY 参数的语法为 BY pattern,pattern 可以是字符串类型键或者是散列类型键的某个字段。如果提供了 BY 参数,SORT 命令将不再依据元素自身的值进行排序,而是对每个元素使用元素的值替换 pattern 中的第一个 * 并获取其值,然后依据该值排序。

127.0.0.1:6379> HMSET item:1 name iphone6 price 5999
OK
127.0.0.1:6379> HMSET item:2 name ipad price 2888
OK
127.0.0.1:6379> HMSET item:3 name applewatch price 8688
OK
127.0.0.1:6379> SADD item:ids 1 2 3
(integer) 3
127.0.0.1:6379> SORT item:ids BY item:*->price
1) "2"
2) "1"
3) "3"

当 pattern 不包含 "*" 时,即常量键名,SORT 命令将不会执行排序操作,因为 Redis 认为这种情况是没有意义的。

当某个元素的 pattern 不存在时,会默认 pattern 的值为 0,如:

127.0.0.1:6379> HSET item:4 name mac
(integer) 1
127.0.0.1:6379> SADD item:ids 4
(integer) 1
127.0.0.1:6379> SORT item:ids BY item:*->price
1) "4"
2) "2"
3) "1"
4) "3"

GET 参数

GET 参数不影响排序,它的作用是使 SORT 命令的返回结果不再是元素自身的值,而是 GET 中指定的键值。

127.0.0.1:6379> HMSET item:1 name iphone6 price 5999
OK
127.0.0.1:6379> HMSET item:2 name ipad price 2888
OK
127.0.0.1:6379> HMSET item:3 name applewatch price 8688
OK
127.0.0.1:6379> SADD item:ids 1 2 3
(integer) 3
127.0.0.1:6379> SORT item:ids BY item:*->price GET item:*->name
1) "ipad"
2) "iphone6"
3) "applewatch"

可以使用 GET # 返回商品的 ID:

127.0.0.1:6379> SORT item:ids BY item:*->price GET # GET item:*->name
1) "2"
2) "ipad"
3) "1"
4) "iphone6"
5) "3"
6) "applewatch"

STORE 参数

如果希望保存排序结果,可以使用 STORE 参数。

127.0.0.1:6379> SORT item:ids BY item:*->price GET # GET item:*->name STORE sorted_items
(integer) 6
127.0.0.1:6379> LRANGE sorted_items 0 -1
1) "2"
2) "ipad"
3) "1"
4) "iphone6"
5) "3"
6) "applewatch"

STORE 参数常用来结合 EXPIRE 命令缓存排序结果。

性能优化

SORT 命令的时间复杂度是 O(N+M*log(M)),其实 N 表示要排序的列表(集合或有序集合)中的元素个数,M 表示要返回的元素个数。

开发过程中应注意以下几点以提高性能:

  1. 尽可能减少带排序键中的数量(使 N 尽可能小)。
  2. 使用 LIMIT 参数只获取需要的数据(使 M 尽可能小)。
  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排序

    1.sort 排序最常见的是sort命令,可以对列表或者有序集合排序,最简单的排序方式如下: > lpush list (integer) > lpush list (integer) & ...

  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. HDU 1828 Picture (线段树+扫描线)(周长并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1828 给你n个矩形,让你求出总的周长. 类似面积并,面积并是扫描一次,周长并是扫描了两次,x轴一次,y ...

  2. POJ 3694 Network (tarjan + LCA)

    题目链接:http://poj.org/problem?id=3694 题意是给你一个无向图n个点,m条边,将m条边连接起来之后形成一个图,有Q个询问,问将u和v连接起来后图中还有多少个桥. 首先用t ...

  3. shape中的属性大全

    首先,看看事例代码 <shape> <!-- 实心 --> <solid android:color="#ff9999"/> <!-- 渐 ...

  4. MPAndroiddChart的使用

    效果图 代码: package com.jiahao.me; import java.util.ArrayList; import java.util.List; import android.app ...

  5. IIS支持其他类型下载

    路径:IIS--默认网站属性-->http 头-->MIME映射 -->文件类型 -->新类型

  6. Win7激活后添加grub引导Linux最简单方法

    因为Win7(Vista同理)的激活方式是通过grub摸你OEM的Slic信息,所以主引导分区MBR被这个grub占用,以此才能激活WIn7.但是如果想同时安装Linux在别的分区,就会产生问题:gr ...

  7. XML Helper XML操作类

    写的一个XML操作类,包括读取/插入/修改/删除. using System;using System.Data;using System.Configuration;using System.Web ...

  8. swift3.0 coredata 的使用

    //swift3.0在语法上有很大的改变,以简单的增删改查为例,如下: //User类如下: import Foundation import CoreData extension User { @n ...

  9. 在mac下安装jdk1.7(转)

    转自:http://vela.diandian.com/post/2012-01-06/15379924 最近呢,想玩玩jdk1.7,不过mac平台下的jvm一直都是Apple自己改的,所有有些麻烦. ...

  10. Mysql分表教程

    一般来说,当我们的数据库的数据超过了100w记录的时候就应该考虑分表或者分区了,这次我来详细说说分表的一些方法.目前我所知道的方法都是MYISAM的,INNODB如何做分表并且保留事务和外键,我还不是 ...