目錄
- 概述
- 詳解
1、概述
Redis支持五種數(shù)據(jù)類型:String(字符串)、Hash(哈希)、List(列表)、Set(集合)、Zset(有序集合)。
2、詳解
1、String(字符串)
定義: String 是 redis 最基本的類型,一個(gè) key 對(duì)應(yīng)一個(gè) value。String 類型是二進(jìn)制安全的。因?yàn)?string 底層的實(shí)現(xiàn)是簡(jiǎn)單動(dòng)態(tài)字符串 sds,是可以修改字符串。
應(yīng)用場(chǎng)景: 單值緩存、對(duì)象緩存、分布式鎖、常規(guī)計(jì)數(shù)(粉絲數(shù)量、評(píng)論數(shù)量)、分布式session共享、分布式全局序列號(hào)。
具體實(shí)現(xiàn):
單值緩存:
set key value
get key
對(duì)象緩存:
set user:1 value(json格式數(shù)據(jù))
mset user:1:name tsingli user:1:balance 1888
mget user:1:name user:1:balance
常規(guī)計(jì)數(shù)器:
incr article:readcount:{文章id}
get article:readcount:{文章id}
分布式系統(tǒng)全局序列號(hào):
incrby orderid 1000 # redis批量生成序列號(hào)提升性能
分布式鎖:
# 相關(guān)操作
線程1: setnx product:1001 true # 返回1代表獲取鎖成功
線程2: setnx product:1001 true # 返回0代表獲取鎖失敗
。。。執(zhí)行業(yè)務(wù)操作
del product:1001 # 執(zhí)行完業(yè)務(wù)釋放鎖
set product:1001 true ex 10 nx # 防止程序意外終止導(dǎo)致死鎖
# 案例
setnx product:1001 true
1.查詢商品1001的庫(kù)存
2.減庫(kù)存
3.重新把減完剩余的庫(kù)存更新回?cái)?shù)據(jù)庫(kù)
del product:1001
setnx 如果插入的key一樣不會(huì)對(duì)數(shù)據(jù)有任何操作,如果第二次對(duì)庫(kù)存再進(jìn)行減對(duì)的話就返回錯(cuò)誤。
2、Hash(哈希)
定義: Hash是一個(gè)鍵值對(duì)集合。他相當(dāng)于java中的雙重map。<key,<filed,value>>。
應(yīng)用場(chǎng)景: 購(gòu)物車。
具體實(shí)現(xiàn):
購(gòu)物車:
# 說(shuō)明:
# 用戶id為1001,商品的編碼是10088。
# 用戶id為key,商品id為field,商品數(shù)量為value。
# 案例:
# 添加商品:
hset cart:1001 10088 1
# 增加數(shù)量:
hincrby cart:1001 10088 1
# 商品總數(shù):
hlen cart:1001
# 刪除商品:
hdel cart:1001 10088
# 獲取購(gòu)物車所有商品:
hgetall cart:1001
3、List(列表)
定義: 列表是簡(jiǎn)單的字符串列表,按照插入順序排序,可以添加一個(gè)元素在列表的頭部或者尾部。
應(yīng)用場(chǎng)景: Stack(棧)= LPUSH + LPOP -> FILO //先進(jìn)后出、Queue(隊(duì)列)= LPUSH + RPOP //先進(jìn)先出、Blocking MQ(阻塞隊(duì)列)= LPUSH + BRPOP //消息隊(duì)列、微博、微信公眾號(hào)消息流。
具體實(shí)現(xiàn):
微博和微信公眾號(hào)消息流:
# 李雷發(fā)微博,消息id為10018
lpush msg:111111 10018
# 韓梅梅車發(fā)微博,消息id為10086
lpush msg:111111 10086
# 查看最新微博消息
lrange msg:11111 0 5 //0至5條微博消息。
4、Set(集合)
定義: Set 是 string 類型的無(wú)序集合。
應(yīng)用場(chǎng)景: 微信抽獎(jiǎng)小程序、微信微博點(diǎn)贊、收藏、標(biāo)簽、關(guān)注模型,就是可能認(rèn)識(shí)的人的關(guān)系。
具體實(shí)現(xiàn):
微信抽獎(jiǎng):
# 點(diǎn)擊參與抽獎(jiǎng)加入集合
sadd key {userId}
# 查看參與抽獎(jiǎng)的所有用戶
smembers key
# 抽取count名中獎(jiǎng)?wù)撸?) // srandmember不會(huì)將元素從集合中刪除
srandmember key [count] //抽取兩名中獎(jiǎng)?wù)?srandmember act:1008 2
# 抽取count名中獎(jiǎng)?wù)撸?) // SPOP會(huì)將元素從集合中刪除
spop key 2
微信微博點(diǎn)贊、收藏、標(biāo)簽:
# 點(diǎn)贊
sadd like:{消息ID} {用戶id}
# 取消點(diǎn)贊
srem like:{消息ID} {用戶id}
# 檢查用戶是否點(diǎn)過(guò)贊
sismember like:{消息ID} {用戶id}
# 獲取點(diǎn)贊的用戶列表
smembers like:{消息ID}
# 獲取點(diǎn)贊的用戶樹(shù)
scard like:{消息ID}
5、Zset(有序集合)
定義: zset和set一樣也是string類型元素的集合,且不允許重復(fù)的成員。不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)dobule類型的分?jǐn)?shù),redis正是通過(guò)分?jǐn)?shù)為集合成員進(jìn)行從小到大的排序,zset的成員是唯一的但是分?jǐn)?shù)可以重復(fù)。