文章目錄
- Redis資料型別
- 一、String資料型別
- 1、append
- 2、set
- 3、strlen
- 4、incr、decr、incrby、decrby
- 5、getset
- 6、setex
- 7、setnx
- 8、mset、mget、msetnx
- 二、List資料型別
- 1、lpush、lpushx、lrange
- 2、lpop、llen
- 3、lrem、lset、lindex、ltrim
- 4、linsert
- 5、rpush、rpushx
- 6、rpop、rpoplpush
- 三、Hash資料型別(散列型別)
- 1、hset、hget、hdel、hexists、hlen、hsetnx
- 2、hincrby
- 3、hmset、hmget、hgetall、hkeys、hvals
- 四、set資料型別(無序集合)
- 1、sadd、smembers、scard、sismember
- 2、spop、srem、srandmember、smove
- 五、Sorted Set資料型別(zset、有序集合)
- 1、zadd、zcard、zcount、zrem、zincrby、zscore、zrank
- 2、zrangebyscore、zremrangebyrank、zremrrangebyscore
- 3、zrevrange、zrevrangebyscore、zrevrank
Redis資料型別
一、String資料型別
概述:String是redis最基本的型別,最大能存盤512MB的資料,String型別是二進制安全的,即可以存盤任何資料、比如數字、圖片、序列化物件等
1、append
1、append #Redis的append命令是往一個key追加value,如果沒有key,則創建一個并且設定value
例:
redis-cli
exists blue
append blue hello
append blue lic
get blue

2、set
2、SET #獲取資料,命令格式為 get key
例:
set blue 'hello lic!'
get blue

3、strlen
3、strlen #獲取指定Key的字符長度
例:
strlen blue

4、incr、decr、incrby、decrby
4、incr #該Key的值遞增1
decr #該Key的值遞減1
incrby #增加指定的整數
decrby #減少指定的整數
例:
set sky 10
incr sky
decr sky
incrby sky 10
decrby sky -46
get sky
del sky
keys *
incr sky
keys *
set sky white
get sky
incr sky


5、getset
5、getset #獲取計數器原有值的同時,并將其設定為新值,這兩個操作原子性的同時完成
例:
incr white
getset white 0
get white
6、setex
6、setex #設定指定Key的過期時間為xx秒
ttl key #查看鍵的剩余存活時間
例:
setex white 20 'kiki'
ttl white
get white
等待20s
get white
ttl white
set white 'kiki'
ttl white

7、setnx
7、setnx #創建指定鍵,若該鍵存在則不執行,不存在則執行
例:
del white
setnx white lic
setnx white kiki
get white

8、mset、mget、msetnx
8、mset #批量設定鍵的值
mget #批量獲取鍵的值
msetnx #批量設定鍵值,若有存在的鍵則不執行
例:
mset k1 blue k2 sky
mget k1 k2
msetnx k2 white k3 cloud
keys k*
msetnx k4 white k3 cloud
keys k*

二、List資料型別
概述:串列的元素型別為string,按照插入順序排序,在串列的頭部或尾部添加元素
1、lpush、lpushx、lrange
1、lpush #該命令會創建該鍵及與其關聯的List,之后在將引數中的values從左到右依次插入到表頭
lpushx #該命令僅當key存在時,將value值插入表頭
lrange #回傳串列中指定區間內的元素,0表示第一個元素,1表示第二個元素
例:
lpush cloud a b c d
lrange cloud 0 -1
lpushx cloudd e
keys c*
lpushx cloud e
lrange cloud 0 -1

2、lpop、llen
2、lpop #移除并回傳第一個元素,從頭開始
llen #查看串列中元素個數

3、lrem、lset、lindex、ltrim
3、lrem #從頭部(left)向尾部(right)變數鏈表,洗掉2個值等于a的元素,回傳值為實際洗掉的數量
lset #將索引值為xxx的元素值設定為新值xxx
lindex #獲取索引值為xxx的元素值,
ltrim #僅保留索引值xxx到xxx的元素
例:
del cloud
lpush cloud a b c b b a
lrange cloud 0 -1
lrem cloud 2 b
lrange cloud 0 -1
lset cloud 1 b
lrange cloud 0 -1
lindex cloud 3
ltrim cloud 0 2
lrange cloud 0 -1

4、linsert
4、linsert #在鍵的xxx元素前|后插入新元素元素
例:
del cloud
lpush cloud a b c d e
lrange cloud 0 -1
linsert cloud before a 0
linsert cloud after e 1
lrange cloud 0 -1

5、rpush、rpushx
5、rpush #將值從左往右依次插入到表尾
rpushx #指定鍵存在時執行,否則不執行
例:
del key1
del key2
rpush key1 a b c d e
lrange key1 0 -1
rpushx key1 f
rpushx key2 f
keys key?

6、rpop、rpoplpush
6、rpop #移除并回傳鍵的第一個元素,從尾開始
rpoplpush #將鍵1尾部元素xxx彈出,同時再插入到鍵2的頭部(原子性的完成這兩步操作)
例:
rpop key1
lrange key1 0 -1
rpoplpush key1 key2
keys key?
lrange key2 0 -1
lrange key1 0 -1
rpoplpush key1 key1
lrange key1 0 -1

三、Hash資料型別(散列型別)
概述:hash用于存盤物件,可以采用這樣的命名方式:物件類別和ID構成鍵名,使用欄位表示物件的屬性,而欄位值則存盤屬性值, 如:存盤 ID 為 2 的汽車物件,
如果Hash中包含很少的欄位,那么該型別的資料也將僅占用很少的磁盤空間,每一個Hash可以存盤4294967295個鍵值對,
1、hset、hget、hdel、hexists、hlen、hsetnx
1、hset #給xxx鍵設定欄位為xxx,值為xxx
hget #獲取xxx鍵,欄位為xxx的值
hdel #洗掉xxx鍵的xxx欄位,成功回傳1
hexists #判斷xxx鍵中的xxx欄位是否存在,存在回傳1
hlen #獲取xxx鍵的欄位數量
hsetnx #給xxx鍵添加新欄位,是否執行基于此欄位是否存在,不管鍵是否存在,回傳1表示執行成功
例:
hset hash field1 a field2 b field3 c
hget hash field1
hdel hash field2
hexists hash field2
hlen hash
hsetnx hash1 field3 d
keys has*
hsetnx hash field3 d

2、hincrby
2、hincrby #給xxx鍵的xxx欄位值加x
例:
hincrby hash3 field1 5
hincrby hash3 field1 -71
3、hmset、hmget、hgetall、hkeys、hvals
3、hmset #批量為xxx鍵創建欄位和賦值
hmget #獲取指定多個欄位值
hgetall #回傳xxx鍵的所有欄位及其值,是逐對列出的
hkeys #僅獲取xxx鍵中所有欄位名
hvals #僅獲取xxx鍵中所有欄位值
例:
del hash4
del hash5
hmset hash4 field1 hello field2 world
hmget hash4 field1 field2
hkeys hash4
hvals hash4
hset hash5 field1 hello field2 lic
hget hash5 field1 field2
hmget hash5 field1 field2
hkeys hash5
hvals hash5

四、set資料型別(無序集合)
概述:無序集合,元素型別為String型別,元素具有唯一性,不允許存在重復的成員,多個集合型別之間可以進行并集、交集和差集運算,
應用范圍:
1.可以使用Redis的Set資料型別跟蹤一些唯一性資料,比如訪問某一博客的唯一IP地址資訊,對于此場景,我們僅需在每次訪問該博客時將訪問者的IP存入Redis中,Set資料型別會自動保證IP地址的唯一性,
2.充分利用Set型別的服務端聚合操作方便、高效的特性,可以用于維護資料物件之間的關聯關系,比如所有購買某一電子設備的客戶ID被存盤在一個指定的Set中,而購買另外一種電子產品的客戶ID被存盤在另外一個Set中,如果此時我們想獲取有哪些客戶同時購買了這兩種商品時,Set的intersections命令就可以充分發揮它的方便和效率的優勢了,
1、sadd、smembers、scard、sismember
1、sadd #將一個或多個成員元素加入到集合中,已經存在于集合的成員元素將被忽略,假如集合 key 不存在,則創建一個只包含添加的元素作成員的集合
smembers #通過smembers命令查看插入的結果,輸出的順序與插入順序無關
scard #獲取集合中成員的數量
sismember #判斷鍵中xxx成員是否存在,回傳0表示不存在,1表示存在
例:
sadd myset a b c d e
smembers myset
scard myset
sismember myset c
sismember myset f

2、spop、srem、srandmember、smove
2、spop #隨機的移除并回傳鍵中的某一成員
srem #從鍵中移出xxx、xxx、xxx成員,并回傳移出成員個數
srandmember #該命令隨機的回傳某一成員
smove #將鍵1的xxx成員移到鍵2,成功回傳1,失敗回傳0
例:
del myset
sadd myset a b c d e
spop myset
smembers myset
srem myset a b c
smembers myset
srandmember myset
smove myset myset1 e
keys myse*

五、Sorted Set資料型別(zset、有序集合)
概述:a、有序集合,元素型別為Sting,元素具有唯一性,不能重復,
b、每個元素都會關聯一個double型別的分數score(表示權重),可以通過權重的大小排序,元素的score可以相同,
應用范圍:
1)可以用于一個大型在線游戲的積分排行榜,每當玩家的分數發生變化時,可以執行ZADD命令更新玩家的分數,此后再通過ZRANGE命令獲取積分TOP10的用戶資訊,當然我們也可以利用ZRANK命令通過username來獲取玩家的排行資訊,最后我們將組合使用ZRANGE和ZRANK命令快速的獲取和某個玩家積分相近的其他用戶的資訊,
2)Sorted-Set型別還可用于構建索引資料,
1、zadd、zcard、zcount、zrem、zincrby、zscore、zrank
1、zadd #將一個或多個成員元素及其分數值加入到有序集當中
zcard #獲取鍵中成員的數量
zcount #分數滿足運算式x <= score <= x的成員的數量
zrem #洗掉成員xxx、xxx,回傳實際洗掉成員的數量
zincrby #成員xxx不存在,zincrby命令將添加該成員并假設其初始分數為0
zscore #獲取成員xxx的分數
zrank #獲取成員xxx的位置索引值
例:
zadd zset 1 a 2 b 3 c 4 d 5 e
zrange zset 0 -1
zrange zset 0 -1 withscores
zrank zset e
zcard zset
zcount zset 2 4
zrem zset a b
zcard zset
zscore zset d
zincrby zset 2 a
zincrby zset -1 a

2、zrangebyscore、zremrangebyrank、zremrrangebyscore
2、zrangebyscore #獲取分數滿足運算式x <= score <= x的成員
zremrangebyrank #洗掉位置索引滿足運算式x <= rank <= x的成員,
zremrrangebyscore #洗掉分數滿足運算式x <= score <= x的成員,并回傳實際洗掉的數量,
例:
del zset
zadd zset 1 a 2 b 3 c 4 d 5 e
zrangebyscore zset 2 4
zrangebyscore zset -inf +inf limit 2 3
zremrangebyscore zset 1 3
zrange zset 0 -1
zremrangebyrank zset 1 2
zrange zset 0 -1

3、zrevrange、zrevrangebyscore、zrevrank
3、zrevrange #以位置索引從高到低的方式獲取并回傳此區間內的成員
zrevrangebyscore #獲取分數滿足運算式x >= score >= x 的成員,并以從高到底的順序輸出,
zrevrank #獲取成員索引
例:
del zset
zadd zset 1 a 2 b 3 c 4 d 5 e
zrange zset 0 -1
zrevrange zset 0 -1
zrevrank zset a
zrank zset a
zrevrangebyscore zset 5 3
zrevrangebyscore zset 3 1 limit 1 2

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/263872.html
標籤:其他
上一篇:校園網規劃與設計(附加完整word檔案和pkt檔案)
下一篇:分布式事務管理:Seata
