sort命令可以对列表类型和有序集合类型进行排序

1)在对有序集合排序的时候会忽略元素的分数,只针对元素的值进行排序
2)sort命令还可以通过​​​alpha​​参数实现按照字典顺序排列非数字元素

sort list alpha

sort命令默认是按照从小到大的顺序排列,可以添加​​desc​​使得其逆序

sort命令还可以支持​​limit​​参数返回指定范围的结果,语法和sql一样。

BY参数

语法为by参考键(字符串类型键或者散列的键名->字段名)。如果提供了by参数,sort命令不依据元素自身值而是对每个元素使用元素的值替换掉参考键的第一个​​*​​然后依据此值进行排序。

sort tag by post:*->time

及为把​​tag​​​排序的参数放到​​*​​​的位置,然后用​​post:*​​​的​​time​​​字段进行排序
​​​*​​​不能放到​​->​​​之后
参考键必须包含​​​*​

Get参数

get参数不影响排序,只是使得sort排序的返回结果为get中的指定键值,其语法和by相同
在一个sort命令中可以有多个get参数

sort tag get post:*->time

及为把​​tag​​​排序的输出放到​​*​​的位置,然后返回time

store参数

可以将结果存入某个键中

sort list store newlist

及将结果放入newlist

性能优化

sort的时间复杂度为O(n+mlog(m)),其中n表示要排序的列表中的元素个数,m表示要返回的元素个数,当n较大时候性能较低,而且在排序前会建立一个长度为n的容器来存储待排序元素,当n足够大的时候会影响性能。

所以要注意
(1)尽可能减少待排序键中元素的数量(n小)
(2)使用limit参数只获取需要的数据(m小)
(3)如果排序数据量大,用store缓存