zset獲取指定score zset型別以及其操作

2021-10-13 02:26:57 字數 4696 閱讀 4874

sorted set型別

sorted sets型別以及其操作

zset是set的一格公升級版本,它在set的基礎上增加了一格順序屬性,這一屬性在新增元素的同時可以指定,每次指定後,zset會自動重新按照新的值調整順序。可以理解為有兩列的mysql表,一列儲存value,一列儲存順序。操作中key理解成zset的名字。

zadd

向名稱為key的zset中新增元素member,score用於排序,如果該元素存在,則更新其順序

127.0.0.1:6379> zadd key [nx|xx] [ch] [incr] score member [score member ...]127.0.0.1:6379> zadd zset 0one

(integer)1

127.0.0.1:6379> zadd zset -1two

(integer)1

zrange

遍歷集合的元素

127.0.0.1:6379> zrange key start stop [withscores] //withscores代表的是否顯示順序號  start和stop代表所在的位置的索引。可以這樣理解:將集合元素依照順序值公升序排序再輸出,start和stop限制遍歷的限制範圍

127.0.0.1:6379> zadd zset -1hhh

(integer)1

127.0.0.1:6379> zrange zset 0 0

1) "hhh"。127.0.0.1:6379> zrange zset 0 -1withscore1) "two"

2) "-1"

3) "one"

4) "0"

zset元素也是不重複的,不要將它理解成為map了,score只是附加的,並不是array中的index,而是代表該元素的順序號

同乙個順序可以有多個元素:

127.0.0.1:6379>  zrange zset 0 -1 withscores

1) "one"

2) "0"

3) "two"

4) "0"

zrem

刪除集合中的member元素

127.0.0.1:6379> zrange zset 0 -1withscores1) "one"

2) "1"

3) "two"

4) "2"

5) "three"

6) "3"

127.0.0.1:6379>zrem zset one

(integer)1

127.0.0.1:6379> zrange zset 0 -1

1) "two"

2) "three"

zincrby

如果在名稱為key的zset中已經存在元素member,則該元素的score增加incremenr否則向該集合中新增該元素,其score的值為increment

127.0.0.1:6379>zincrby key increment member127.0.0.1:6379> zincrby zset 2two"4"

127.0.0.1:6379> zincrby zset 3four"3"

127.0.0.1:6379> zrange zset 0 -1withscores1) "four"

2) "3"

3) "three"

4) "3"

5) "two"

6) "4"

127.0.0.1:6379>

127.0.0.1:6379> zincrby zset -2two"2"

zrank

返回名稱為key的zset中member元素的排名(類似索引從0開始)(按score從小到大排序)即下標

127.0.0.1:6379>zrank key member127.0.0.1:6379> zrange zset 0 -1withscores1) "two"

2) "2"

3) "four"

4) "3"

5) "three"

6) "3"

127.0.0.1:6379>zrank zset two

(integer)0

127.0.0.1:6379>zrank zset four

(integer)1

127.0.0.1:6379>zrank zset three

(integer)2

注意得到的是排名而不是順序值score

zrevrank

rev:代表翻轉

返回名稱為key的zset中member元素的排名(按score從大到小排序),即下標

127.0.0.1:6379> zrange zset 0 -1withscores1) "hhh"

2) "-1"

3) "hi"

4) "2"

5) "two"

6) "2"

7) "four"

8) "3"

9) "three"

10) "3"

127.0.0.1:6379>zrank zset hhh

(integer)0

127.0.0.1:6379>zrevrank zset hhh

(integer)4

zrevrange

按照順序值降序排序然後顯示指定下標內的值

127.0.0.1:6379>zrevrange key start stop [withscores]127.0.0.1:6379> zrevrange zset 0 -1withscores1) "three"

2) "3"

3) "four"

4) "3"

5) "two"

6) "2"

7) "hi"

8) "2"

9) "hhh"

10) "-1"

127.0.0.1:6379> zrange zset 0 -1withscores1) "hhh"

2) "-1"

3) "hi"

4) "2"

5) "two"

6) "2"

7) "four"

8) "3"

9) "three"

10) "3"

zrangebyscore

就是利用score公升序排序,而是返回集合中score給定區間內的元素。範圍內的元素一句score公升序排序。start和stop代表的不再是index而是score

127.0.0.1:6379>zrangebyscore key min max [withscores] [limit offset count]127.0.0.1:6379> zrange zset 0 -1withscores1) "hhh"

2) "-1"

3) "hi"

4) "2"

5) "two"

6) "2"

7) "four"

8) "3"

9) "three"

10) "3"

127.0.0.1:6379> zrangebyscore zset -1 2withscores1) "hhh"

2) "-1"

3) "hi"

4) "2"

5) "two"

6) "2"

zcount

返回集合中score指定區間中元素的數量

127.0.0.1:6379>zcount key min max127.0.0.1:6379> zcount zset -1 2(integer)3

zcard

返回集合中的集合元素

127.0.0.1:6379>zcard zset

(integer)5

zremrangebyrank

刪除集合中排名在指定區間內的元素,排名意思是index,排序值是score

127.0.0.1:6379>zremrangebyrank key start stop127.0.0.1:6379> zrange zset 0 -1withscores1) "hhh"

2) "-1"

3) "hi"

4) "2"

5) "two"

6) "2"

7) "four"

8) "3"

9) "three"

10) "3"

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

127.0.0.1:6379> zrange zset 0 -1withscores1) "four"

2) "3"

3) "three"

4) "3"

remrangebyscore

刪除集合中排序值在指定區間的元素

127.0.0.1:6379>zrangebyscore key min max [withscores] [limit offset count]127.0.0.1:6379> zrange zset 0 -1withscores1) "four"

2) "3"

3) "three"

4) "3"

127.0.0.1:6379> zremrangebyscore zset 0 1(integer)0

127.0.0.1:6379> zremrangebyscore zset 3 3(integer)2

127.0.0.1:6379> zrange zset 0 -1withscores

(empty list orset)

git獲取指定路徑 Git 獲取指定檔案或者資料夾

在進行專案開發的時候,有時候會有這樣的需求那就是 我們只希望從git倉庫裡取指定的檔案或者資料夾出來。在svn裡面,這非常容易實現,因為svn基於檔案方式儲存,而git卻是基於元資料方式分布式儲存檔案資訊的,它會在每一次clone的時候將所有資訊都取回到本地,即相當於在你的機器上生成乙個轉殖版的版本...

jQuery 獲取指定元素

1 利用標籤名 獲取元素 標籤名 2 通過id獲取元素 id name 3 通過 類名獲取元素 classname 4 一次性獲取多個元素 元素名,元素名,元素名 5 通過指定層次關係獲取元素 祖先 子孫 父 子 前 後 兄 弟 6 根據元素的屬性值獲取元素 attribute attribute ...

獲取excel指定列

def get time process 如果表不存在,則建立workbook 存在則匯入 wb workbook 表不存在,建立 wb load workbook process free result.xlsx 表存在,匯入 建立和使用sheet ws1 wb.create sheet free...