Home | 簡體中文 | 繁體中文 | 雜文 | 打賞(Donations) | Github | OSChina 博客 | 雲社區 | 雲棲社區 | Facebook | Linkedin | 知乎專欄 | 視頻教程 | About

34.12. LIST 數據類型

獲取 list 列表長度

			
127.0.0.1:6379> TYPE "logstash:redis"
list
127.0.0.1:6379> LLEN "logstash:redis"
(integer) 69
127.0.0.1:6379> lpop "logstash:redis"
127.0.0.1:6379> 	
127.0.0.1:6379> LLEN "logstash:redis"
(integer) 68
			
			
			
1. LPUSH/LPUSHX/LRANGE:
/> redis-cli    #在Shell提示符下啟動redis客戶端工具。
redis 127.0.0.1:6379> del queue:test
(integer) 1
#queue:test鍵並不存在,該命令會創建該鍵及與其關聯的List,之後在將參數中的values從左到右依次插入。
redis 127.0.0.1:6379> lpush queue:test a b c d
(integer) 4
#取從位置0開始到位置2結束的3個元素。
redis 127.0.0.1:6379> lrange queue:test 0 2
1) "d"
2) "c"
3) "b"
#取鏈表中的全部元素,其中0表示第一個元素,-1表示最後一個元素。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "d"
2) "c"
3) "b"
4) "a"
#queue:test2鍵此時並不存在,因此該命令將不會進行任何操作,其返回值為0。
redis 127.0.0.1:6379> lpushx queue:test2 e
(integer) 0
#可以看到queue:test2沒有關聯任何List Value。
redis 127.0.0.1:6379> lrange queue:test2 0 -1
(empty list or set)
#queue:test鍵此時已經存在,所以該命令插入成功,並返回鏈表中當前元素的數量。
redis 127.0.0.1:6379> lpushx queue:test e
(integer) 5
#獲取該鍵的List Value的頭部元素。
redis 127.0.0.1:6379> lrange queue:test 0 0
1) "e"

2. LPOP/LLEN:
redis 127.0.0.1:6379> lpush queue:test a b c d
(integer) 4
redis 127.0.0.1:6379> lpop queue:test
"d"
redis 127.0.0.1:6379> lpop queue:test
"c"
#在執行lpop命令兩次後,鏈表頭部的兩個元素已經被彈出,此時鏈表中元素的數量是2
redis 127.0.0.1:6379> llen queue:test
(integer) 2

3. LREM/LSET/LINDEX/LTRIM:
#為後面的示例準備測試數據。
redis 127.0.0.1:6379> lpush queue:test a b c d a c
(integer) 6
#從頭部(left)向尾部(right)變數鏈表,刪除2個值等於a的元素,返回值為實際刪除的數量。
redis 127.0.0.1:6379> lrem queue:test 2 a
(integer) 2
#看出刪除後鏈表中的全部元素。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "c"
2) "d"
3) "c"
4) "b"
#獲取索引值為1(頭部的第二個元素)的元素值。
redis 127.0.0.1:6379> lindex queue:test 1
"d"
#將索引值為1(頭部的第二個元素)的元素值設置為新值e。
redis 127.0.0.1:6379> lset queue:test 1 e
OK
#查看是否設置成功。
redis 127.0.0.1:6379> lindex queue:test 1
"e"
#索引值6超過了鏈表中元素的數量,該命令返回nil。
redis 127.0.0.1:6379> lindex queue:test 6
(nil)
#設置的索引值6超過了鏈表中元素的數量,設置失敗,該命令返回錯誤信息。
redis 127.0.0.1:6379> lset queue:test 6 hh
(error) ERR index out of range
#僅保留索引值0到2之間的3個元素,注意第0個和第2個元素均被保留。
redis 127.0.0.1:6379> ltrim queue:test 0 2
OK
#查看trim後的結果。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "c"
2) "e"
3) "c"

4. LINSERT:
#刪除該鍵便于後面的測試。
redis 127.0.0.1:6379> del queue:test
(integer) 1
#為後面的示例準備測試數據。
redis 127.0.0.1:6379> lpush queue:test a b c d e
(integer) 5
#在a的前面插入新元素a1。
redis 127.0.0.1:6379> linsert queue:test before a a1
(integer) 6
#查看是否插入成功,從結果看已經插入。注意lindex的index值是0-based。
redis 127.0.0.1:6379> lindex queue:test 0
"e"
#在e的後面插入新元素e2,從返回結果看已經插入成功。
redis 127.0.0.1:6379> linsert queue:test after e e2
(integer) 7
#再次查看是否插入成功。
redis 127.0.0.1:6379> lindex queue:test 1
"e2"
#在不存在的元素之前或之後插入新元素,該命令操作失敗,並返回-1。
redis 127.0.0.1:6379> linsert queue:test after k a
(integer) -1
#為不存在的Key插入新元素,該命令操作失敗,返回0。
redis 127.0.0.1:6379> linsert queue:test1 after a a2
(integer) 0

5. RPUSH/RPUSHX/RPOP/RPOPLPUSH:
#刪除該鍵,以便于後面的測試。
redis 127.0.0.1:6379> del queue:test
(integer) 1
#從鏈表的尾部插入參數中給出的values,插入順序是從左到右依次插入。
redis 127.0.0.1:6379> rpush queue:test a b c d
(integer) 4
#通過lrange的可以獲悉rpush在插入多值時的插入順序。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
#該鍵已經存在並且包含4個元素,rpushx命令將執行成功,並將元素e插入到鏈表的尾部。
redis 127.0.0.1:6379> rpushx queue:test e
(integer) 5
#通過lindex命令可以看出之前的rpushx命令確實執行成功,因為索引值為4的元素已經是新元素了。
redis 127.0.0.1:6379> lindex queue:test 4
"e"
#由於queue:test2鍵並不存在,因此該命令不會插入數據,其返回值為0。
redis 127.0.0.1:6379> rpushx queue:test2 e
(integer) 0
#在執行rpoplpush命令前,先看一下queue:test中鏈表的元素有哪些,注意他們的位置關係。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
5) "e"
#將queue:test的尾部元素e彈出,同時再插入到queue:test2的頭部(原子性的完成這兩步操作)。
redis 127.0.0.1:6379> rpoplpush queue:test queue:test2
"e"
#通過lrange命令查看queue:test在彈出尾部元素後的結果。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
#通過lrange命令查看queue:test2在插入元素後的結果。
redis 127.0.0.1:6379> lrange queue:test2 0 -1
1) "e"
#將source和destination設為同一鍵,將queue:test中的尾部元素移到其頭部。
redis 127.0.0.1:6379> rpoplpush queue:test queue:test
"d"
#查看移動結果。
redis 127.0.0.1:6379> lrange queue:test 0 -1
1) "d"
2) "a"
3) "b"
4) "c"