Redis排序命令Sort深入解析
引言
Redis是一款快速、優(yōu)秀的鍵值對數(shù)據(jù)庫,提供豐富的數(shù)據(jù)結(jié)構(gòu)能在各種場景下實現(xiàn)功能,同時也提供豐富的命令來完成各種各樣的功能,本篇文章將深入淺出的解析Sort命令的原理以及使用
原理
Sort 命令用來對list、set、zset對象進行排序,返回排序后的結(jié)果
Sort命令會使用一個與原來對象等長的數(shù)組,數(shù)組中的節(jié)點RedisSortObject存儲了元素(指向?qū)?yīng)元素)以及權(quán)值,排序就是根據(jù)權(quán)值來排序,權(quán)值默認情況下是浮點型,如果要排序的是字符串則權(quán)值為字符串對象
等長數(shù)組中的RedisSortObject節(jié)點會與排序?qū)ο笾械脑匾灰粚?yīng)記錄元素對象的地址和權(quán)值
再使用快速排序根據(jù)等長數(shù)組中RedisSortObject對象中的權(quán)值進行排序(默認升序)
注意:排序只在新數(shù)組中操作,并沒有改變原來的對象
圖中排序流程對應(yīng)以下命令操作
127.0.0.1:6379> lpush number 1 3 5 (integer) 3 127.0.0.1:6379> lrange number 0 -1 1) "5" 2) "3" 3) "1" 127.0.0.1:6379> sort number 1) "1" 2) "3" 3) "5"
alpha 選項
alpha選項對字符串進行排序,如果對字符串進行排序不使用alpha會報出字符串無法轉(zhuǎn)換為浮點型(默認浮點型)的異常
使用alpha選項則是對字符串進行排序
127.0.0.1:6379> sadd set z x c n r a (integer) 6 127.0.0.1:6379> smembers set 1) "x" 2) "n" 3) "a" 4) "r" 5) "z" 6) "c" 127.0.0.1:6379> sort set alpha 1) "a" 2) "c" 3) "n" 4) "r" 5) "x" 6) "z"
by 選項
如果希望不是根據(jù)當(dāng)前集合的元素進行排序,而是根據(jù)其他Key來排序則使用 by 選項
by *-value
表示獲取當(dāng)前元素的key代替*
與-value
拼接得到新的Key,查詢新Key得到的值拿來排序
這種情況下RedisSortObject中記錄的權(quán)值為新Key的值
比如當(dāng)前元素是cc 則新key為 cc-value ,查詢到新key值為88 因此排中間
如果新key結(jié)果為字符串 則要使用alpha 選項
127.0.0.1:6379> sadd set tom cc jack (integer) 3 127.0.0.1:6379> mset tom-value 99 cc-value 88 jack-value 77 OK 127.0.0.1:6379> smembers set 1) "cc" 2) "jack" 3) "tom" 127.0.0.1:6379> sort set by *-value 1) "jack" 2) "cc" 3) "tom" #使用新key的值為字符串時使用alpha 127.0.0.1:6379> mset tom-str a cc-str b jack-str c OK 127.0.0.1:6379> sort set alpha by *-str 1) "tom" 2) "cc" 3) "jack"
limit 選項
limit用來限制返回的數(shù)量,使用方式類比MySQL的limit
127.0.0.1:6379> sort set alpha by *-str 1) "tom" 2) "cc" 3) "jack" 127.0.0.1:6379> sort set alpha by *-str limit 0 2 1) "tom" 2) "cc" 127.0.0.1:6379> sort set alpha by *-str limit 1 2 1) "cc" 2) "jack"
get 選項
與by類似,但是by作用的是排序值,而get作用的是返回值
如果希望返回值不是當(dāng)前元素的值,而是其他key的返回值,則使用get
get *-res
表示獲取當(dāng)前元素的key代替*
與-res
拼接得到新的Key,查詢新Key得到的值用于返回結(jié)果
比如當(dāng)前元素是cc 則新key為 cc-res ,查詢到新key值為cc-result 因此響應(yīng)時返回cc-result
127.0.0.1:6379> sort set alpha by *-str limit 0 3 1) "tom" 2) "cc" 3) "jack" 127.0.0.1:6379> mset tom-res tom-result cc-res cc-result jack-res jack-result OK 127.0.0.1:6379> sort set alpha by *-str limit 0 3 get *-res 1) "tom-result" 2) "cc-result" 3) "jack-result"
store 選項
sort不是對原本的對象在原地進行排序,而是使用新數(shù)組來保存排序結(jié)果
使用store選項能將排序結(jié)果,使用list命令來生成Key,key為list類型
127.0.0.1:6379> sort set alpha by *-str limit 0 3 get *-res 1) "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) 3 127.0.0.1:6379> type setresult list 127.0.0.1:6379> lrange setresult 0 -1 1) "tom-result" 2) "cc-result" 3) "jack-result"
總結(jié)
本篇文章圍繞Sort命令,深入淺出的解析Sort命令原理以及使用
Sort命令使用新的等長數(shù)組來對list、set、zset對象進行排序,其中數(shù)組中的節(jié)點RedisSortObject存儲元素地址和權(quán)值,先使用節(jié)點記錄要排序?qū)ο笾性氐牡刂泛蜋?quán)值,再使用快速排序根據(jù)權(quán)值進行排序然后返回
默認情況下權(quán)值為浮點型,如果是對字符串類型排序,需要使用alpha選項;
想要使用其他key作為權(quán)值排序時使用by選項;
限制結(jié)果集返回使用limit;
想要返回其他key的值時使用get選項;
想存儲結(jié)果并生成列表對象時使用store
參考資料
以上就是Redis排序命令Sort深入解析的詳細內(nèi)容,更多關(guān)于Redis Sort排序命令的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
php結(jié)合redis實現(xiàn)高并發(fā)下的搶購、秒殺功能的實例
下面小編就為大家?guī)硪黄猵hp結(jié)合redis實現(xiàn)高并發(fā)下的搶購、秒殺功能的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12Redis?延時任務(wù)實現(xiàn)及與定時任務(wù)區(qū)別詳解
這篇文章主要為大家介紹了Redis?延時任務(wù)實現(xiàn)及與定時任務(wù)區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06淺談RedisTemplate和StringRedisTemplate的區(qū)別
本文主要介紹了RedisTemplate和StringRedisTemplate的區(qū)別及個人見解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06解密Redis助力雙11背后電商秒殺系統(tǒng)(推薦)
這篇文章主要介紹了解密Redis助力雙11背后電商秒殺系統(tǒng),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10