1. 程式人生 > >redis系列:通過文章點贊排名案例學習sortedset命令

redis系列:通過文章點贊排名案例學習sortedset命令

前言

這一篇文章將講述Redis中的sortedset型別命令,同樣也是通過demo來講述,其他部分這裡就不在贅述了。

案例

demo功能是文章點贊排名等等,整個demo的大致頁面如下。

準備工作

首先定義一個儲存文章的key

private static final String ZSET_KEY = "articleList";

redis操作物件

private RedisTemplate redisTemplate;
//string 命令操作物件
private ValueOperations valueOperations;
//zset 命令操作物件
private ZSetOperations zSetOperations;

sortedset在Redis中的結構可以看下圖(圖片來源於Redis in Action)。

圖片來源於Redis in Action

列表查詢

@RequestMapping(value = "/getList/{sortType}", method = RequestMethod.GET)
public Set getList(@PathVariable String sortType) {
    //如果沒有資料,則新增10條資料
    if (zSetOperations.size(ZSET_KEY) == 0){
        for
(int i = 1; i <= 10; i++) { zSetOperations.add(ZSET_KEY,"文章:"+i, (int)(Math.random()*10+i)); } } //ASC根據分數從小到大排序,DESC反之 if ("ASC".equals(sortType)){ return zSetOperations.rangeWithScores(ZSET_KEY, 0, -1); } else { return zSetOperations.reverseRangeWithScores(ZSET_KEY, 0
, -1); } }

這裡為了省去一個個新增資料的麻煩,就在獲取列表資料中加了個判斷。當文章資料為0時,預設新增10條資料,設定隨機score加上所在的索引。
然後根據url中的引數sortType來決定返回的資料是按照分數升序還是降序排序。功能效果如下

命令介紹

命令 用例 描述
ZADD ZADD key [NX|XX][CH] [INCR] score member [score member …] 將所有指定成員新增到鍵為key有序集合(sorted set)裡面
ZRANGE ZRANGE key start stop [WITHSCORES] 返回有序集key中,指定區間內的成員。其中成員的位置按score值遞減(從小到大)來排列。
ZREVRANGE ZREVRANGE key start stop [WITHSCORES] 返回有序集key中,指定區間內的成員。其中成員的位置按score值遞減(從大到小)來排列。

贊或踩

java程式碼如下

@RequestMapping(value = "/star", method = RequestMethod.POST)
public boolean starOrUnStar(String member, String type) {
    if ("UP".equals(type)){
        zSetOperations.incrementScore(ZSET_KEY, member, 1);
    } else {
        zSetOperations.incrementScore(ZSET_KEY, member, -1);
    }
    return true;
}

根據type決定是否加減分數,當type為UP時表示贊,為其他(DOWN)時表示踩。功能效果如下

命令介紹

命令 用例 描述
ZINCRBY ZINCRBY key increment member 為有序集key的成員member的score值加上增量increment

升降序排名

java程式碼如下

@RequestMapping(value = "/rank/{type}/{member}", method = RequestMethod.GET)
public Long rank(@PathVariable String member, @PathVariable String type) {
    Long rank = null;
    if ("ASC".equals(type)){
        rank = zSetOperations.rank(ZSET_KEY, member);
    } else {
        rank = zSetOperations.reverseRank(ZSET_KEY, member);
    }

    return rank;
}

根據type決定是升序排名還是降序排名,如果是ASC則呼叫rank方法獲取升序排名,其他則呼叫reverseRank獲取降序排名。與下方redis命令類似

ZRANK articleList "文章1"
ZREVRANK articleList "文章1"

頁面效果圖如下

命令介紹

命令 用例 描述
ZRANK ZRANK key member 返回有序集key中成員member的排名。其中有序整合員按score值遞增(從小到大)順序排列。排名以0為底,也就是說,score值最小的成員排名為0。
ZREVRANK ZREVRANK key member 返回有序集key中成員member的排名,其中有序整合員按score值從大到小排列。

其他命令

獲取屬性

命令 用例 描述
ZCARD ZCARD key 返回key的有序集元素個數。
ZCOUNT ZCOUNT key min max 返回有序集key中,score值在min和max之間(預設包括score值等於min或max)的成員個數。
ZLEXCOUNT ZLEXCOUNT key min max 用於計算有序集合中指定成員之間的成員數量。
ZSCORE ZSCORE key member 返回有序集key中,成員member的score值。
ZCARD命令

返回key的有序集元素個數。
ZCARD key
返回值:key存在的時候,返回有序集的元素個數,否則返回0。

redis客戶端執行的命令如下

zadd zCardKey 1 one
zcard zCardKey

下面是java程式碼

@Test
public void zCard() {
    jedis.zadd("zCardKey",1, "one");
    jedis.zadd("zCardKey",2, "two");

    System.out.println(jedis.zcard("zCardKey"));

    System.out.println(zSetOperations.size("zCardKey"));
}
ZCOUNT命令

返回有序集key中,score值在min和max之間(預設包括score值等於min或max)的成員數量。
ZCOUNT key min max
返回值:指定分數範圍的元素個數。

redis客戶端執行的命令如下

zadd zCountKey 1 one 2 two 3 three 4 four
zcount zCountKey 2 3

執行結果如下

下面是java程式碼

@Test
public void zCount() {
    jedis.zadd("zCountKey",1, "one");
    jedis.zadd("zCountKey",2, "two");
    jedis.zadd("zCountKey",3, "three");
    jedis.zadd("zCountKey",4, "four");

    System.out.println(jedis.zcount("zCountKey",2, 3));

    System.out.println(zSetOperations.count("zCountKey",2, 3));
}
ZLEXCOUNT命令

計算有序集合中指定成員之間的成員數量(按成員字典正序排序),可以使用 - 和 + 表示score最小值和最大值
ZLEXCOUNT key min max

redis客戶端執行的命令如下

ZADD zLexCountKey 2 "b" 1 "a" 3 "c" 5 "e" 4 "d"
ZLEXCOUNT zLexCountKey - +
ZLEXCOUNT zLexCountKey [b [d

執行結果如下

下面是java程式碼

@Test
public void zLexCount() {
    zSetOperations.add("zLexCountKey", "b", 2);
    zSetOperations.add("zLexCountKey", "a", 1);
    zSetOperations.add("zLexCountKey", "c", 3);
    zSetOperations.add("zLexCountKey", "e", 5);
    zSetOperations.add("zLexCountKey", "d", 4);

    System.out.println(jedis.zlexcount("zLexCountKey", "-", "+"));

    System.out.println(jedis.zlexcount("zLexCountKey", "[b", "[d"));
}
ZSCORE命令

返回有序集key中,成員member的score值。
ZSCORE key member
返回值:成員member的score值

redis客戶端執行的命令如下

zadd zScoreKey 1 one
ZSCORE zScoreKey one

下面是java程式碼

@Test
public void zScore() {
    jedis.zadd("zScoreKey",1, "one");

    System.out.println(jedis.zscore("zScoreKey", "one"));

    System.out.println(zSetOperations.score("zScoreKey", "one"));
}

獲取成員

命令 用例 描述
ZRANGEBYLEX ZRANGEBYLEX key min max [LIMIT offset count] 返回指定成員區間內的成員,按成員字典正序排序。
ZRANGEBYSCORE ZRANGEBYSCORE key min max [WITHSCORES]``[LIMIT offset count] 返回所有符合score條件的成員
ZREVRANGEBYLEX ZREVRANGEBYLEX key max min [LIMIT offset count] 返回指定成員區間內的成員,按成員字典倒序排序。
ZREVRANGEBYSCORE ZREVRANGEBYSCORE key max min [WITHSCORES]``[LIMIT offset count] 返回有序集合中指定分數區間內的成員,分數由高到低排序。
ZSCAN ZSCAN key cursor [MATCH pattern]``[COUNT count] 請參考 SCAN
ZRANGEBYLEX命令

返回指定成員區間內的成員,按成員字典正序排序。https://redis.io/commands/zrangebylex
ZRANGEBYLEX key min max[LIMIT offset count]
返回值:指定成員範圍的元素列表。

redis客戶端執行的命令如下

ZADD zRangeByLexKey 0 ba 0 a 0 ab 0 aa 0 b
ZRANGEBYLEX zRangeByLexKey - +
ZRANGEBYLEX zRangeByLexKey [aa (ba

執行結果如下

下面是java程式碼

@Test
public void zRangeByLex() {
    zSetOperations.add("zRangeByLexKey", "ba", 0);
    zSetOperations.add("zRangeByLexKey", "a", 0);
    zSetOperations.add("zRangeByLexKey", "ab", 0);
    zSetOperations.add("zRangeByLexKey", "aa", 0);
    zSetOperations.add("zRangeByLexKey", "b", 0);

    System.out.println(jedis.zrangeByLex("zRangeByLexKey", "-", "+"));

    RedisZSetCommands.Range range = new RedisZSetCommands.Range();
    range.gte("aa");
    range.lt("ba");
    System.out.println(zSetOperations.rangeByLex("zRangeByLexKey",range));
}
ZRANGEBYSCORE命令

獲取score在範圍之內的資料。min和max可以是-inf和+inf
ZRANGEBYSCORE key min max[WITHSCORES]``[LIMIT offset count]

redis客戶端執行的命令如下

ZADD zRangeByScoreKey 1 ba 2 a 3 ab 4 aa 5 b
ZRANGEBYSCORE zRangeByScoreKey -inf +inf
ZRANGEBYSCORE zRangeByScoreKey 2 4

執行結果如下

下面是java程式碼

@Test
public void zRangeByScore() {
    zSetOperations.add("zRangeByScoreKey", "ba", 1);
    zSetOperations.add("zRangeByScoreKey", "a", 2);
    zSetOperations.add("zRangeByScoreKey", "ab", 3);
    zSetOperations.add("zRangeByScoreKey", "aa", 4);
    zSetOperations.add("zRangeByScoreKey", "b", 5);

    System.out.println(jedis.zrangeByScore("zRangeByScoreKey", "-inf", "+inf"));

    RedisZSetCommands.Range range = new RedisZSetCommands.Range();
    System.out.println(zSetOperations.rangeByScore("zRangeByScoreKey", 2, 4));
}

移除相關命令

命令 用例 描述
ZREM ZREM key member [member …] 刪除有序集合中的成員
ZREMRANGEBYLEX ZREMRANGEBYLEX key min max 刪除名稱按字典由低到高排序成員之間所有成員
ZREMRANGEBYRANK ZREMRANGEBYRANK key start stop 移除有序集key中,指定排名(rank)區間內的所有成員。
ZREMRANGEBYSCORE ZREMRANGEBYSCORE key min max 移除有序集key中,所有score值介於min和max之間(包括等於min或max)的成員
ZREM命令

ZREM key member [member …]
返回值:有序集合中刪除的成員個數

redis客戶端執行的命令如下

ZADD zRemKey 1 "one" 2 "two" 3 "three"
ZREM zRemKey one
ZRANGE zRemKey 0 -1

執行結果如下

下面是java程式碼

@Test
public void zRem() {
    zSetOperations.add("zRemKey", "one", 1);
    zSetOperations.add("zRemKey", "two", 2);
    zSetOperations.add("zRemKey", "three", 3);

    //jedis.zrem("zRemKey", "one");
    zSetOperations.remove("zRemKey", "one");

    System.out.println(zSetOperations.range("zRemKey", 0 , -1));
}

交併集

命令 用例 描述
ZINTERSTORE ZINTERSTORE destination numkeys key [key ...]``[WEIGHTS weight] [SUM|MIN|MAX] 計算給定的numkeys個有序集合的交集,並且把結果放到destination中
ZUNIONSTORE ZUNIONSTORE destination numkeys key [key ...]``[WEIGHTS weight] [SUM|MIN|MAX] 計算給定的numkeys個有序集合的並集,並且把結果放到destination中
ZINTERSTORE命令

計算給定的numkeys個有序集合的交集,並且把結果放到destination中。
在給定要計算的key和其它引數之前,必須先給定key個數(numberkeys)。
預設情況下,結果中一個元素的分數是有序集合中該元素分數之和,前提是該元素在這些有序集合中都存在。因為交集要求其成員必須是給定的每個有序集合中的成員,結果集中的每個元素的分數和輸入的有序集合個數相等。
對於WEIGHTS和AGGREGATE引數的描述,參見命令ZUNIONSTORE。
如果destination存在,就把它覆蓋。

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
返回值:結果有序集合destination中元素個數。
redis客戶端執行的命令如下

ZADD zInterStoreKey1 1 "one" 2 "two"
ZADD zInterStoreKey2 1 "one" 2 "two" 3 "three"
ZINTERSTORE zInterStoreSumResult 2 zInterStoreKey1 zInterStoreKey2 WEIGHTS 2 3

ZRANGE zInterStoreSumResult 0 -1 WITHSCORES

執行結果如下

下面是java程式碼

@Test
public void zInterStore() {
    zSetOperations.add("zInterStoreKey1", "one", 1);
    zSetOperations.add("zInterStoreKey1", "two", 2);

    zSetOperations.add("zInterStoreKey2", "one", 1);
    zSetOperations.add("zInterStoreKey2", "two", 2);
    zSetOperations.add("zInterStoreKey2", "three", 3);


    ZParams zParams = new ZParams();
    zParams.weightsByDouble(2, 3);
    zParams.aggregate(ZParams.Aggregate.SUM);
    jedis.zinterstore("zInterStoreSumResult", zParams, "zInterStoreKey1", "zInterStoreKey2");

    printTuple("zInterStoreSumResult", jedis.zrangeWithScores("zInterStoreSumResult", 0, -1));
}
ZUNIONSTORE命令

計算給定的numkeys個有序集合的並集,並且把結果放到destination中。
WEIGHTS引數相當於權重,預設就是1,可以給不同的key設定不同的權重
AGGREGATE引數預設使用的引數SUM,還可以選擇MIN或者MAX。這個引數決定結果集的score是取給定集合中的相加值、最小值還是最大值
ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...] ] [AGGREGATE SUM|MIN|MAX]

redis客戶端執行的命令如下

ZADD zUnionStoreKey1 1 "one" 2 "two"
ZADD zUnionStoreKey2 1 "one" 2 "two" 3 "three"
ZUNIONSTORE zUnionStoreSumResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3
ZUNIONSTORE zUnionStoreMinResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MIN
ZUNIONSTORE zUnionStoreMaxResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MAX
     *
ZRANGE zUnionStoreSumResult 0 -1 WITHSCORES
ZRANGE zUnionStoreMinResult 0 -1 WITHSCORES
ZRANGE zUnionStoreMaxResult 0 -1 WITHSCORES

執行結果如下

下面是java程式碼

@Test
public void zUnionStore() {
    zSetOperations.add("zUnionStoreKey1", "one", 1);
    zSetOperations.add("zUnionStoreKey1", "two", 2);

    zSetOperations.add("zUnionStoreKey2", "one", 1);
    zSetOperations.add("zUnionStoreKey2", "two", 2);
    zSetOperations.add("zUnionStoreKey2", "three", 3);


    ZParams zParams = new ZParams();
    zParams.weightsByDouble(2, 3);
    zParams.aggregate(ZParams.Aggregate.SUM);
    jedis.zunionstore("zUnionStoreSumResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2");

    //求最小值
    zParams.aggregate(ZParams.Aggregate.MIN);
    jedis.zunionstore("zUnionStoreMinResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2");

    //求最大值
    zParams.aggregate(ZParams.Aggregate.MAX);
    jedis.zunionstore("zUnionStoreMaxResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2");

    //spring
    zSetOperations.unionAndStore("zUnionStoreKey1", "zUnionStoreKey2", "zUnionStoreResult");


    printTuple("zUnionStoreSumResult", jedis.zrangeWithScores("zUnionStoreSumResult", 0, -1));
    printTuple("zUnionStoreMinResult", jedis.zrangeWithScores("zUnionStoreMinResult", 0, -1));
    printTuple("zUnionStoreMaxResult", jedis.zrangeWithScores("zUnionStoreMaxResult", 0, -1));
    printTuple("zUnionStoreResult", jedis.zrangeWithScores("zUnionStoreResult", 0, -1));
}

還是那句話建議學習的人最好每個命令都去敲下,加深印象。

紙上得來終覺淺,絕知此事要躬行。————出自《冬夜讀書示子聿》

相關推薦

redis系列通過文章排名案例學習sortedset命令

前言 這一篇文章將講述Redis中的sortedset型別命令,同樣也是通過demo來講述,其他部分這裡就不在贅述了。 案例 demo功能是文章點贊排名等等,整個demo的大致頁面如下。 準備工作 首先定義一個儲存文章的key p

redis系列通過demo學習list命令

art 隊列 tps 創建 介紹 count stat 其他 圈子 前言 這一篇文章將講述Redis中的list類型命令,同樣也是通過demo來講述,其他部分這裏就不在贅述了。 項目Github地址:https://github.com/rainbowda/learnWay

redis系列通過共同好友案例學習set命令

val 執行 其他命令 vat system 得到 hash src per 前言 這一篇文章將講述Redis中的set類型命令,同樣也是通過demo來講述,其他部分這裏就不在贅述了。 項目Github地址:https://github.com/rainbowda/lear

Redis + DB +訊息佇列 實現高效的文章踩功能

需求說明 使用者可點贊或踩,每贊一次,“贊”數量+1,每踩一次,“踩”數量+1,“點贊”和“點踩” 當天內二選一當天內有效 場景:使用者A 點贊 文章a,文章a 點贊量+1 ,同一使用者,同一文章 當天再次點選無效,贊與踩二選一,隔天再次點選有效 表設計 文章的

Spring Boot + Redis + MQ實現高併發功能專案實戰

開心一笑 【最後一次警告看我CSDN部落格的人,你們都他媽給老子小心點,首先我不管你是什麼身份,什麼背景,混的有多牛逼,是不是老闆,是不是社會人,這些我都不知道,我也都不在意,你們給我記住,都給我認真點看清楚:最近天氣實在很涼,大家多穿衣服,彆著涼了,知道不!

Vue系列通過vue-router如何傳遞參數

2個 定義 ole read 傳遞 通過 ons 鏈接 lang (1) 設置好路由配置 router.map({ ‘/history/:deviceId/:dataId‘: { name: ‘history‘, // give the route a na

redis系列哨兵

daemon -o sel 進行 的區別 monitor 參數 解決 發布 1 簡介 Sentinel(哨兵)是Redis 的高可用性解決方案:通過哨兵可以創建一個當主服務器出現故障時自動將從服務器升級為主服務器的一個分布式系統。解決了主從復制出現故障時需要人為幹預的問題。

功能豐富的WordPress插件不少,但對於要在主題中集成簡單文章功能的需求,插件就顯得不合

localhost cal _id domain pda eric func 功能 numeric add_action(‘wp_ajax_nopriv_bigfa_like‘, ‘bigfa_like‘); add_action(‘wp_ajax_bigfa_like‘,

java多執行緒系列通過對戰遊戲學習CyclicBarrier

CyclicBarrier是java.util.concurrent包下面的一個工具類,字面意思是可迴圈使用(Cyclic)的屏障(Barrier),通過它可以實現讓一組執行緒到達一個屏障(也可以叫同步點)時被阻塞,直到最後一個執行緒到達屏障時,所有被屏障攔截的執

WordPress非外掛實現文章功能

功能豐富的WordPress點贊外掛不少,但對於要在主題中整合簡單文章點贊功能的需求,外掛就顯得不合適,於是乎非外掛實現文章點贊功能的方法就誕生,實現思路是:可以通過ajax實時顯示點贊數量,自定義欄位儲存贊數量,Cookies禁止重新點贊。 具體操作步驟。 1、在當前主

redis系列主從複製

1 簡介 這篇文章主要講述Redis的主從複製功能。會依次從環境搭建、功能測試和原理分析幾個方面進行介紹。 2 準備工作 伺服器架構圖如下  啟動主伺服器101,使用info replication命令檢視狀態,可以看到role為master(也就是角色為主主伺服器)

Django為文章模板檔案

一 模板檔案 {% extends "base.html" %} {% load staticfiles %} {% block title %}{{ article.title }}{% endblock %} {% block content %} <!-- with發起

WordPress新增AJAX文章功能

來自Fatesinger,文章贊功能隨處可見,例如無覓的相關文章工具、百度分享等等。如果想要給主題專門整合點贊功能,還是得需要下面的程式碼實現。用自定義欄位儲存贊數量,通過Cookies來禁止重複贊。 加入至Functions.php檔案中: a

Redis應用2-Redis實現開發者頭條頁面功能

開發者頭條是一個資源豐富的程式猿學習網站。當網站釋出新的內容的時候,內容優秀的總是會被點贊。今天就利用Redis實現這個小小的功能。 為什麼使用Redis而不是MySQL實現? Redis 和 MySQL應用場景不同。 從效率來說: Redis

redis系列redis啟動宿主到Windows服務中

首先 要啟動redis伺服器端,然後在執行redis客戶端,然後通過Windows的service-install命令,輸入: redis-server --service-install re

Redis系列總結--這幾你會了嗎?

文章原創於公眾號:程式猿周先森。本平臺不定時更新,喜歡我的文章,歡迎關注我的微信公眾號。 前面幾篇已經對Redis中幾個關鍵知識點做了介紹,本篇主要對Redis系列做一下總結以及對Redis中常見面試題簡單進行介紹一下。首先我們對前面幾篇談到的Redis知識點進行總結。 第1篇:Redis系列開篇文章可以

Selenium實現微博自動化運營關注、、評論

目錄 Selenium 是什麼? 一、核心程式碼 二、步驟分解 1.開啟瀏覽器 2.訪問微博登入頁 3.輸入賬號密碼 4.點選登入 5.通過人機

閉包的講解及案例

緩存 函數返回值 函數 一個 自動 cti 對象式 defined 函數式   1.閉包:函數在調用的時候會形成一個私有的作用域,對內部的變量起到保護的作用,這就是閉包   2.變量的銷毀:     1.人為銷毀  var a=12;  a=null;     2.自然銷毀

ansible-role角色通過一個批量部署nginx範例學習role

進程 必須 ansi 守護 啟動 它的 ble 處理器 變量 1簡單的介紹role ansible自1.2版本引入的新特性,用於層次性、結構化地組織playbook roles能夠根據層次型結構自動裝載變量文件、tasks以及handlers等。 簡單來講,roles就

初識Redis系列之三Redis支持的數據類型及使用

ted print 數據類型 eight 排序 sorted ring hang 無序 支持的數據類型有五種: string(字符串)、hash(哈希)、list(列表)、set(集合)及zset(sorted set:有序集合); 下面分別對這幾種類型進行簡單的Redis