redis push/pop(List)的17條命令

 

 

 

1、Blpop 命令移出並獲取列表的第一個元素, 若是列表沒有元素會阻塞列表直到等待超時或發現可彈出元素爲止。
redis 127.0.0.1:6379> BLPOP LIST1 LIST2 .. LISTN TIMEOUT
返回值
若是列表爲空,返回一個 nil 。 不然,返回一個含有兩個元素的列表,第一個元素是被彈出元素所屬的 key ,第二個元素是被彈出元素的值。
redis 127.0.0.1:6379> BLPOP list1 100
在以上實例中,操做會被阻塞,若是指定的列表 key list1 存在數據則會返回第一個元素,不然在等待100秒後會返回 nil 。
(nil)
(100.06s)redis

 

取數據lpop有個加強版本,blpop(block left pop)阻塞版本,使用方法:blpop key1 key2 ... keyn 10blog

同時預獲取多個key的值,並設置超時時間爲10s,若是全部key,有些key有value就當即返回,若是全部key都沒有value就阻塞10秒返回索引

關於blpop多個key返回數據的順序,好比blpop mylist mylist2 5這個命令,先檢查mylist有數據就返回,若是沒有數據,就檢查mylist2依次。。。。直到全部key檢查完若是都沒有數據就阻塞。隊列

這種從多個隊列裏面取數據的方式能夠用來作優先級的隊列,好比mylist隊列的優先級高於mylist2,push的時候,高優先級就push到mylist裏面,普通優先級就push到mylist2裏面,ci

這樣就會先取mylist裏面的高優先級的數據來處理。rem

可是,若是遇到隊列的優先級等級過多,好比有(0-9999)個優先級,上面就不行了。解決思路是插入的時候先把數據取出來本身實現二分查找找出該插入的位置,用lset命令插入。搜索

若是數據過多,好比隊列有幾十萬,能夠把隊列分紅幾十個或幾百個小隊列,好比0號隊列存優先級爲(0-1000),1號隊列存優先級爲(1001-2000)的數據,依次。。。。。方法

 

 

 

 

 

2、Brpop 命令移出並獲取列表的最後一個元素, 若是列表沒有元素會阻塞列表直到等待超時或發現可彈出元素爲止。im

 


3、Brpoplpush 命令從列表中彈出一個值,將彈出的元素插入到另一個列表中並返回它; 若是列表沒有元素會阻塞列表直到等待超時或發現可彈出元素爲止。
redis 127.0.0.1:6379> BRPOPLPUSH LIST1 ANOTHER_LIST TIMEOUT
假如在指定時間內沒有任何元素被彈出,則返回一個 nil 和等待時長。 反之,返回一個含有兩個元素的列表,第一個元素是被彈出元素的值,第二個元素是等待時長。數據

# 非空列表
redis> BRPOPLPUSH msg reciver 500
"hello moto" # 彈出元素的值
(3.38s) # 等待時長

redis> LLEN reciver
(integer) 1

redis> LRANGE reciver 0 0
1) "hello moto"

# 空列表
redis> BRPOPLPUSH msg reciver 1
(nil)
(1.34s)

 


4、Lindex 命令用於經過索引獲取列表中的元素。你也能夠使用負數下標,以 -1 表示列表的最後一個元素, -2 表示列表的倒數第二個元素,以此類推。
redis 127.0.0.1:6379> LINDEX KEY_NAME INDEX_POSITION
列表中下標爲指定索引值的元素。 若是指定索引值不在列表的區間範圍內,返回 nil 。

實例
redis 127.0.0.1:6379> LPUSH mylist "World"
(integer) 1

redis 127.0.0.1:6379> LPUSH mylist "Hello"
(integer) 2

redis 127.0.0.1:6379> LINDEX mylist 0
"Hello"

redis 127.0.0.1:6379> LINDEX mylist -1
"World"

redis 127.0.0.1:6379> LINDEX mylist 3 # index不在 mylist 的區間範圍內
(nil)

 


5、Linsert 命令用於在列表的元素前或者後插入元素。 當指定元素不存在於列表中時,不執行任何操做。 當列表不存在時,被視爲空列表,不執行任何操做。 若是 key 不是列表類型,返回一個錯誤。
redis 127.0.0.1:6379> LINSERT KEY_NAME BEFORE EXISTING_VALUE NEW_VALUE
若是命令執行成功,返回插入操做完成以後,列表的長度。 若是沒有找到指定元素 ,返回 -1 。 若是 key 不存在或爲空列表,返回 0 。

實例
redis 127.0.0.1:6379> RPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> RPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LINSERT list1 BEFORE "bar" "Yes"
(integer) 3
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "foo"
2) "Yes"
3) "bar"

 

 

6、Llen 命令用於返回列表的長度。 若是列表 key 不存在,則 key 被解釋爲一個空列表,返回 0 。 若是 key 不是列表類型,返回一個錯誤。
redis 127.0.0.1:6379> LLEN KEY_NAME
實例
redis 127.0.0.1:6379> RPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> RPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LLEN list1
(integer) 2

 

7、Lpop 命令用於移除並返回列表的第一個元素。
redis 127.0.0.1:6379> LLEN KEY_NAME
列表的第一個元素。 當列表 key 不存在時,返回 nil 。

實例
redis 127.0.0.1:6379> RPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> RPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LPOP list1
"foo"

 

8、Lpush 命令將一個或多個值插入到列表頭部。 若是 key 不存在,一個空列表會被建立並執行 LPUSH 操做。 當 key 存在但不是列表類型時,返回一個錯誤。
redis 127.0.0.1:6379> LPUSH KEY_NAME VALUE1.. VALUEN

返回值
執行 LPUSH 命令後,列表的長度。

實例
127.0.0.1:6379> LPUSH list1 "foo"
(integer) 1
127.0.0.1:6379> LPUSH list1 "bar"
(integer) 2
127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "foo"


9、Lpushx 將一個或多個值插入到已存在的列表頭部,列表不存在時操做無效。
redis 127.0.0.1:6379> LPUSHX KEY_NAME VALUE1.. VALUEN

返回值
LPUSHX 命令執行以後,列表的長度。

實例
127.0.0.1:6379> LPUSH list1 "foo"
(integer) 1
127.0.0.1:6379> LPUSHX list1 "bar"
(integer) 2
127.0.0.1:6379> LPUSHX list2 "bar"
(integer) 0
127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "foo"

 

10、Lrange 返回列表中指定區間內的元素,區間以偏移量 START 和 END 指定。 其中 0 表示列表的第一個元素, 1 表示列表的第二個元素,以此類推。 你也能夠使用負數下標,以 -1 表示列表的最後一個元素, -2 表示列表的倒數第二個元素,以此類推。
redis 127.0.0.1:6379> LRANGE KEY_NAME START END

返回值
一個列表,包含指定區間內的元素。

實例
redis 127.0.0.1:6379> LPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> LPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LPUSHX list1 "bar"
(integer) 0
redis 127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "bar"
3) "foo"


11、Lrem 根據參數 COUNT 的值,移除列表中與參數 VALUE 相等的元素。
COUNT 的值能夠是如下幾種:
count > 0 : 從表頭開始向表尾搜索,移除與 VALUE 相等的元素,數量爲 COUNT 。
count < 0 : 從表尾開始向表頭搜索,移除與 VALUE 相等的元素,數量爲 COUNT 的絕對值。
count = 0 : 移除表中全部與 VALUE 相等的值。
redis 127.0.0.1:6379> LREM KEY_NAME COUNT VALUE

返回值
被移除元素的數量。 列表不存在時返回 0 。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 4
redis 127.0.0.1:6379> LREM mylist -2 "hello"
(integer) 2

 

 

12、Lset 經過索引來設置元素的值。當索引參數超出範圍,或對一個空列表進行 LSET 時,返回一個錯誤。關於列表下標的更多信息,請參考 LINDEX 命令。

redis 127.0.0.1:6379> LSET KEY_NAME INDEX VALUE

返回值
操做成功返回 ok ,不然返回錯誤信息。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 4
redis 127.0.0.1:6379> LSET mylist 0 "bar"
OK
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1: "bar"
2) "hello"
3) "foo"
4) "hello"

 

十3、Ltrim 對一個列表進行修剪(trim),就是說,讓列表只保留指定區間內的元素,不在指定區間以內的元素都將被刪除。
下標 0 表示列表的第一個元素,以 1 表示列表的第二個元素,以此類推。 你也能夠使用負數下標,以 -1 表示列表的最後一個元素, -2 表示列表的倒數第二個元素,以此類推。

redis 127.0.0.1:6379> LTRIM KEY_NAME START STOP

返回值
命令執行成功時,返回 ok 。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 4
redis 127.0.0.1:6379> LTRIM mylist 1 -1
OK
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"
3) "bar"

 

十4、Rpop 命令用於移除並返回列表的最後一個元素。

redis 127.0.0.1:6379> RPOP KEY_NAME

返回值
列表的最後一個元素。 當列表不存在時,返回 nil 。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 4
redis 127.0.0.1:6379> RPOP mylist
OK
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "hello"
3) "foo"

 

 

十5、Rpoplpush 命令用於移除列表的最後一個元素,並將該元素添加到另外一個列表並返回。

redis 127.0.0.1:6379> RPOPLPUSH SOURCE_KEY_NAME DESTINATION_KEY_NAME

返回值
被彈出的元素。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 3
redis 127.0.0.1:6379> RPOPLPUSH mylist myotherlist
"bar"
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"

 

十6、Rpush 命令用於將一個或多個值插入到列表的尾部(最右邊)。若是列表不存在,一個空列表會被建立並執行 RPUSH 操做。 當列表存在但不是列表類型時,返回一個錯誤。注意:在 Redis 2.4 版本之前的 RPUSH 命令,都只接受單個 value 值。

redis 127.0.0.1:6379> RPUSH KEY_NAME VALUE1..VALUEN

返回值
執行 RPUSH 操做後,列表的長度。

實例
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 3
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"
3) "bar"

 

十7、Rpushx命令用於將一個或多個值插入到已存在的列表尾部(最右邊)。若是列表不存在,操做無效。

redis 127.0.0.1:6379> RPUSHX KEY_NAME VALUE1..VALUEN

返回值
執行 Rpushx 操做後,列表的長度。

實例redis 127.0.0.1:6379> RPUSH mylist "hello"(integer) 1redis 127.0.0.1:6379> RPUSH mylist "foo"(integer) 2redis 127.0.0.1:6379> RPUSHX mylist2 "bar"(integer) 0redis 127.0.0.1:6379> LRANGE mylist 0 -11) "hello"2) "foo"

相關文章
相關標籤/搜索