欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis有序集合類型的常用命令小結(jié)

 更新時間:2016年09月26日 10:59:53   投稿:daisy  
這篇文章先是給大家簡單介紹了一下有序集合類型,然后詳細整理了關(guān)于Redis有序集合類型的常用命令,通過整理的這些命令相信會給大家的工作或?qū)W習(xí)帶來一定的幫助,有需要的朋友們下面來一起看看吧。

一、有序集合類型

有序集合類型,大家從名字上應(yīng)該就可以知道,實際上就是在集合類型上加了個有序而已。Redis中的有序集合類型,實際上是在集合類型上,為每個元素都關(guān)聯(lián)一個分數(shù),有序?qū)嶋H上說的是分數(shù)有序,我們根據(jù)分數(shù)的范圍獲取集合及其他操作。集合的元素依然是不能夠相同的,但是分數(shù)可以相同。

下面列舉有序集合和類型和列表類型的相似處:

      ①兩者都是有序的(廢話!)

      ②兩者都可以獲得某一范圍的元素

下面列舉區(qū)別:

      ①列表是鏈表實現(xiàn)的,靠近兩邊的數(shù)據(jù)讀取極快,而元素過多后獲取中間元素的速度則會很慢;有序集合類型使用的散列表和跳躍表(Skip list)實現(xiàn)的,所以讀取哪部分的數(shù)據(jù)都差不多(時間復(fù)雜度是O(logN))。

      ②列表中不能簡單的調(diào)整元素的位置,但是有序集合可以(通過改變分數(shù))。

      ③有序集合比列表費內(nèi)存(要存儲分數(shù)、散列、跳躍表)。

二、Redis有序集合的常用命令

Redis有序集合的常用命令有:zadd,zrange,zremrangebyrank,zremrangebyscore,zcard等,這些都是使用頻率比較高的,還有一些參數(shù)的說明等。下面來看看一起看看吧。

1、ZADD命令

將一個或多個 member 元素及其 score 值加入到有序集 key 當(dāng)中。

如果某個 member 已經(jīng)是有序集的成員,那么更新這個 member score 值,并通過重新插入這個 member 元素,來保證該 member 在正確的位置上。

score 值可以是整數(shù)值或雙精度浮點數(shù)。

先用zadd命令批量添加一些元素到有序集合中,后面的操作都是基于這個集合進行。

127.0.0.1:6379> zadd myzadd 1 a 2 b 3 c 4 d 5 e 6 f 7 d 8 e 9 f 10 tanteng.me
(integer) 7

如圖所示:

有序集合最特別的地方在于score,有了分值可以做很多事情,這個score不僅可以理解為分值,有時也會存時間戳,或者ip的整形形式,可以靈活運用。

2、ZRANGE命令

語法:ZRANGE key start stop [WITHSCORES]

zrange命令用于返回有序集合中給定區(qū)間的元素。start從0開始,stop是結(jié)束下標(biāo),如果是負數(shù)表示從倒數(shù)開始,-1倒數(shù)第一個,-2倒數(shù)第二個……

看下面的操作一目了然。

127.0.0.1:6379> zrange myzadd 0 1
1) "a"
2) "b"
127.0.0.1:6379> zrange myzadd 0 5
1) "a"
2) "b"
3) "c"
4) "d"
5) "e"
6) "f"
127.0.0.1:6379> zrange myzadd 1 5
1) "b"
2) "c"
3) "d"
4) "e"
5) "f"
127.0.0.1:6379> zrange myzadd 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
5) "e"
6) "f"
7) "tanteng.me"

加上WITHSCORES參數(shù)顯示分值:

127.0.0.1:6379> zrange myzadd 0 -1 WITHSCORES
 1) "a"
 2) "1"
 3) "b"
 4) "2"
 5) "c"
 6) "3"
 7) "d"
 8) "7"
 9) "e"
10) "8"
11) "f"
12) "9"
13) "tanteng.me"
14) "10"

3、ZREMRANGEBYRANK命令

語法:ZREMRANGEBYRANK key start stop

移除有序集中指定排名(rank)區(qū)間內(nèi)的所有成員。start從0開始,stop可以為負數(shù),表示倒過來第幾位。

127.0.0.1:6379> zremrangebyrank myzadd 0 2
(integer) 3

執(zhí)行這個命令就刪除了前三個元素a,b,c.

4、ZREMRANGEBYSCORE命令

語法:ZREMRANGEBYSCORE key min max

移除有序集 key 中,所有 score 值介于 min 和 max 之間(包括等于 min 或 max )的成員。

127.0.0.1:6379> zremrangebyscore myzadd 7 8
(integer) 2

這樣一來就把分值是7和8的元素d,e移除了.

ZREMRANGEBYRANKZREMRANGEBYSCORE從字面上很好理解,都是移除元素,一個根據(jù)下標(biāo),一個根據(jù)分值。

5、ZCARD命令

語法:ZCARD key

返回有序集合的基數(shù)。

127.0.0.1:6379> zcard myzadd
(integer) 2

經(jīng)過前面的刪除元素操作,現(xiàn)在只剩2個元素了。

6、ZCOUNT命令

語法:ZCOUNT key min max

ZCOUNT命令和ZCARD命令的不同是,ZCOUNT支持根據(jù)范圍返回元素個數(shù)。

由于集合元素都差不多刪沒了,重新添加一組元素:

127.0.0.1:6379> zadd new 100 www.baidu.com 900 www.tanteng.me 12 www.yahoo.com 90 www.xunlei.com 88 www.juanpi.com
(integer) 5

如圖所示:

現(xiàn)在返回分值在80和100之間的成員數(shù)量。

127.0.0.1:6379> zcount new 80 100
(integer) 3

返回3個。

在Redis里面,還有個參數(shù)inf,-inf表示第一個成員,+inf表示最后一個。

127.0.0.1:6379> zcount new 80 +inf
(integer) 4

這里就返回4個數(shù)量,+inf這里表示沒有限制最高分值的意思。

總結(jié)

以上就是關(guān)于Redis有序集合類型常用命令的全部內(nèi)容,文章總結(jié)的還是很詳細的,希望能對大家的學(xué)習(xí)或者工作帶來一些便捷,如果有大家有疑問也可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 爬蟲技術(shù)之分布式爬蟲架構(gòu)的講解

    爬蟲技術(shù)之分布式爬蟲架構(gòu)的講解

    今天小編就為大家分享一篇關(guān)于爬蟲技術(shù)之分布式爬蟲架構(gòu)的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Redis fork進程分配不到內(nèi)存解決方案

    Redis fork進程分配不到內(nèi)存解決方案

    這篇文章主要介紹了Redis fork進程分配不到內(nèi)存解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • Redis RDB與AOF持久化方式詳細講解

    Redis RDB與AOF持久化方式詳細講解

    Redis是基于內(nèi)存的數(shù)據(jù)結(jié)構(gòu)服務(wù)器,保存了大量的鍵值對數(shù)據(jù),所以持久化到磁盤是非常必要的,Redis提供了兩種持久化的方式,分別是RDB和AOF。下面我們看下這兩種持久化方式的具體實現(xiàn)原理
    2022-11-11
  • Redis保證數(shù)據(jù)不丟失的兩種方法

    Redis保證數(shù)據(jù)不丟失的兩種方法

    Redis 實現(xiàn)數(shù)據(jù)不丟失的關(guān)鍵在于使用了多種持久化機制,以確保數(shù)據(jù)在內(nèi)存和磁盤之間的持久性,本文給大家介紹了Redis保證數(shù)據(jù)不丟失的兩種方法,持久化和集群運行,我們分別來看它們兩的具體實現(xiàn)細節(jié),感興趣的同學(xué)跟著小編一起來看看吧
    2023-11-11
  • Redis Cluster添加、刪除的完整操作步驟

    Redis Cluster添加、刪除的完整操作步驟

    這篇文章主要給大家介紹了關(guān)于Redis Cluster添加、刪除的完整操作步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)下吧。
    2017-09-09
  • Redis分布式鎖如何實現(xiàn)續(xù)期

    Redis分布式鎖如何實現(xiàn)續(xù)期

    這篇文章主要介紹了Redis分布式鎖如何實現(xiàn)續(xù)期的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • RedisTemplate常用操作方法總結(jié)(set、hash、list、string等)

    RedisTemplate常用操作方法總結(jié)(set、hash、list、string等)

    本文主要介紹了RedisTemplate常用操作方法總結(jié),主要包括了6種常用方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Redis利用Pipeline加速查詢速度的方法

    Redis利用Pipeline加速查詢速度的方法

    這篇文章主要給大家介紹了關(guān)于Redis利用Pipeline加速查詢速度的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • redis配置文件中常用配置詳解

    redis配置文件中常用配置詳解

    這篇文章主要介紹了redis配置文件中常用配置詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • redis限流的實際應(yīng)用

    redis限流的實際應(yīng)用

    這篇文章主要介紹了redis限流的實際應(yīng)用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04

最新評論