1. 程式人生 > >redis push/pop(List)的17條命令

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

插入 ger com 1.3 解釋 不執行 時間 從表 方法

一、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)

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

同時預獲取多個key的值,並設置超時時間為10s,如果所有key,有些key有value就立即返回,如果所有key都沒有value就阻塞10秒返回

技術分享圖片

技術分享圖片

關於blpop多個key返回數據的順序,比如blpop mylist mylist2 5這個命令,先檢查mylist有數據就返回,如果沒有數據,就檢查mylist2依次。。。。直到所有key檢查完如果都沒有數據就阻塞。

這種從多個隊列裏面取數據的方式可以用來做優先級的隊列,比如mylist隊列的優先級高於mylist2,push的時候,高優先級就push到mylist裏面,普通優先級就push到mylist2裏面,

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

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

如果數據過多,比如隊列有幾十萬,可以把隊列分成幾十個或幾百個小隊列,比如0號隊列存優先級為(0-1000),1號隊列存優先級為(1001-2000)的數據,依次。。。。。

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


三、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)


四、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)


五、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"

六、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

七、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"

八、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"


九、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"

十、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"


十一、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

十二、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"

十三、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"

十四、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"

十五、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"

十六、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"

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

redis 127.0.0.1:6379> RPUSHX KEY_NAME VALUE1..VALUEN

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

實例
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> RPUSHX mylist2 "bar"
(integer) 0
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"

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