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...