03.Redis常用的型別(二)
Redis常用的型別
書接上文 02.Redis常用的型別(一)
lists
底層是雙向連結串列,有序(根據插入序有序)並且允許重複元素。
l開頭基本上都是從左往右操作。
r開頭基本上都是從右往左操作。
同向命令可以實現棧的操作,比如:lpush和lpop,rpush和rpop。
反向命令可以實現佇列的操作,比如:lpush和rpop。
lrange
取出範圍內的元素,0代表左面的第一個元素,-1代表右面的第一個元素,以此類推。
127.0.0.1:6379> lpush list1 v1 v2 v3 v4 (integer) 4 127.0.0.1:6379> lrange list1 0 -1 1) "v4" 2) "v3" 3) "v2" 4) "v1" 127.0.0.1:6379> lrange list1 0 -2 1) "v4" 2) "v3" 3) "v2" 127.0.0.1:6379>
還有可以基於陣列操作
lindex
取出某一位元素的值。
lset
覆蓋某一位元素的值。
lrem
移除前/後幾位為value的元素,正數代表從前開始計算,負數代表從後開始計算。
linsert
向指定value前/後出入元素,如果有相同的只能操作第一次出現的元素。
127.0.0.1:6379> lindex list1 0 "v4" 127.0.0.1:6379> lset list1 -1 vvv OK 127.0.0.1:6379> LRANGE list1 0 -1 1) "v4" 2) "v3" 3) "v2" 4) "vvv" 127.0.0.1:6379> lrem list1 -2 vvv (integer) 1 127.0.0.1:6379> LRANGE list1 0 -1 1) "v4" 2) "v3" 3) "v2" 127.0.0.1:6379> LINSERT list1 after v2 vv (integer) 4 127.0.0.1:6379> LRANGE list1 0 -1 1) "v4" 2) "v3" 3) "v2" 4) "vv" 127.0.0.1:6379> LINSERT list1 before v2 vv (integer) 5 127.0.0.1:6379> LRANGE list1 0 -1 1) "v4" 2) "v3" 3) "vv" 4) "v2" 5) "vv" 127.0.0.1:6379>
blpop
阻塞等待某個key的value,0代表一直阻塞,配合 rpush
當做單播佇列使用,FIFO 先進先出原則。
客戶端一
127.0.0.1:6379> blpop k1 0
客戶端二
127.0.0.1:6379> rpush k1 v1
(integer) 1
127.0.0.1:6379>
客戶端一
127.0.0.1:6379> blpop k1 0
1) "k1"
2) "v1"
(17.57s)
127.0.0.1:6379>
hashes
redis的命令設計的很方便,都是h開頭的,也有針對map value的計算指令 HINCRBY、HINCRBYFLOAT等。
也有人使用以下方式代表hash型別,個人感覺有點不嚴謹。
127.0.0.1:6379> set k1::mapkey mapValue
OK
127.0.0.1:6379> get k1::mapkey
"mapValue"
127.0.0.1:6379>
sets
Redis Set 是 String 的無序排列。
SADD
指令把新的元素新增到 set 中。對 set 也可做一些其他的操作,比如測試一個給定的元素是否存在,對不同 set 取交集,並集或差,等等
都是以s開頭,方便記憶區分。
交集指令:sinter
、sinterstore
並集指令:sunion
、sunionstore
差集指令:sdiff
求差集,具有方向性,只求第一個key
隨機取元素:srandmember
不會影響原來的資料
count的範圍
正數:取出一個去重的結果集(不能超過已有集)
負數:取出一個帶有重複的結果集,一定能滿足數量
0:不返回
可在抽獎的場景使用:
可重複中獎(count負數)。
不可重複中獎(count正數)。
sorted sets
有序集,去重有序,元素需給出分值。
每個元素有正反向索引。
如果分值一樣,按照名稱的字典序排。
實體記憶體預設左小右大的,不會隨命令發生變化,比如zrange和zrevrange
在新增的時候需要給出score。
127.0.0.1:6379> zadd set 0 v1 2 v2 3 v3
(integer) 3
127.0.0.1:6379> zrange set 0 -1
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> ZREVRANGE set 0 -1
1) "v3"
2) "v2"
3) "v1"
127.0.0.1:6379> type set
zset
127.0.0.1:6379> ZRANK set v2
(integer) 1
127.0.0.1:6379> ZRANK set v1
(integer) 0
127.0.0.1:6379> zadd set 4 v4
(integer) 1
127.0.0.1:6379> ZRANGE set 0 -1
1) "v1"
2) "v2"
3) "v3"
4) "v4"
127.0.0.1:6379> ZRANGE set 0 -1 -withscores
(error) ERR syntax error
127.0.0.1:6379> ZRANGE set 0 -1 withscores
1) "v1"
2) "0"
3) "v2"
4) "2"
5) "v3"
6) "3"
7) "v4"
8) "4"
127.0.0.1:6379>
底層結構是skiplist 跳錶,每個元素增加後隨機造層,用空間換時間的思想