Redis類型及使用場(chǎng)景總結(jié)

Redis支持?jǐn)?shù)據(jù)的持久化,可以將內(nèi)存中的數(shù)據(jù)保存在磁盤中,重啟的時(shí)候可以再次加載進(jìn)行使用。
Redis不僅僅支持簡(jiǎn)單的key-value類型的數(shù)據(jù),同時(shí)還提供list,set,zset,hash等數(shù)據(jù)結(jié)構(gòu)的存儲(chǔ)。
Redis支持?jǐn)?shù)據(jù)的備份,即master-slave模式的數(shù)據(jù)備份。

數(shù)據(jù)類型及使用場(chǎng)景總結(jié):

類型 特點(diǎn) 使用場(chǎng)景
string(字符串) 二進(jìn)制安全的,就是可以包含任何數(shù)據(jù),比如jpg圖片或者序列化的對(duì)象。 驗(yàn)證碼、token等
hash(哈希) 是一個(gè) string 類型的 field 和 value 的映射表,特別適合用于存儲(chǔ)對(duì)象 存儲(chǔ)用戶信息、購物車、詳情頁等
list(列表) 雙向鏈表,添加一個(gè)元素到列表的左邊或右邊 最新消息排行(評(píng)論列表)、消息隊(duì)列等
set(集合) 通過哈希表實(shí)現(xiàn),無序集合、唯一 抽獎(jiǎng)隨機(jī)事件、共同好友、統(tǒng)計(jì)網(wǎng)站的所有ip、數(shù)組處理等
sorted set(有序集合) 有序集合、唯一 排行榜等

常見使用場(chǎng)景例子:
① (活躍)用戶統(tǒng)計(jì)
查看任意時(shí)間用戶的登錄天數(shù)

127.0.0.1:6379> SETBIT user1 0 1     # 第1天登錄
(integer) 0
127.0.0.1:6379> SETBIT user1 2 1     # 第3天登錄
(integer) 0
127.0.0.1:6379> SETBIT user1 3 1     # 第4天登錄
(integer) 0
127.0.0.1:6379> BITCOUNT user1 0 -1    # 求user1總共登錄天數(shù),返回3
(integer) 3


127.0.0.1:6379> SETBIT 01/01 1 1    # 用戶1在01/01登錄
(integer) 0
127.0.0.1:6379> SETBIT 01/02 2 1    # 用戶2在01/02登錄
(integer) 0
127.0.0.1:6379> BITOP OR orKey 01/01 01/02  #求01/01、01/02這兩天登錄用戶數(shù),這里取or
(integer) 1
127.0.0.1:6379> BITCOUNT orKey # 求01/01、01/02這兩天登錄用戶數(shù),返回2
(integer) 2
127.0.0.1:6379> SETBIT 01/02 1 1    # 用戶1在01/02也登錄了
(integer) 0
127.0.0.1:6379> BITOP OR orKey 01/01 01/02    # 取or
(integer) 1
127.0.0.1:6379> BITCOUNT orKey  # 求01/01、01/02這兩天登錄用戶數(shù),返回2,因?yàn)檫@兩天只有用戶1和用戶2登錄,所以只有2個(gè)人
(integer) 2

② 評(píng)論列表(list列表)
list類型的LTRIM命令
對(duì)一個(gè)列表進(jìn)行修剪(trim),就是說,讓列表只保留指定區(qū)間內(nèi)的元素,不在指定區(qū)間之內(nèi)的元素都將被刪除。

127.0.0.1:6379> lpush list d1 d2 d3 d4 d5 d6
(integer) 6
127.0.0.1:6379> lrange list 0 -1
1) "d6"
2) "d5"
3) "d4"
4) "d3"
5) "d2"
6) "d1"
127.0.0.1:6379> ltrim list 0 -3
OK
127.0.0.1:6379> lrange list 0 -1
1) "d6"
2) "d5"
3) "d4"
4) "d3"

③ 抽獎(jiǎng)隨機(jī)事件(set集合)

127.0.0.1:6379> sadd k1 d1 d2 d3 d2
(integer) 3
127.0.0.1:6379> smembers k1
1) "d3"
2) "d1"
3) "d2"
127.0.0.1:6379> srandmember k1 5
1) "d1"
2) "d3"
3) "d2"
127.0.0.1:6379> srandmember k1 -5
1) "d1"
2) "d1"
3) "d2"
4) "d2"
5) "d2"

// 抽獎(jiǎng),不重復(fù)單個(gè)人抽獎(jiǎng)
127.0.0.1:6379> spop k1
"d2"
127.0.0.1:6379> spop k1
"d1"
127.0.0.1:6379> spop k1
"d3"
127.0.0.1:6379> spop k1
(nil)
127.0.0.1:6379>

// 數(shù)組處理,可用于好友推薦系統(tǒng)等
127.0.0.1:6379> sadd k1 a b c d  // 添加k1集合
(integer) 4
127.0.0.1:6379> sadd k2 c d e f // 添加k2集合
(integer) 4
127.0.0.1:6379> sinter k1 k2 // k1 k2取交集
1) "d"
2) "c"
127.0.0.1:6379> sunion k1 k2 // k1 k2取并集
1) "b"
2) "a"
3) "f"
4) "e"
5) "d"
6) "c"
127.0.0.1:6379> sunionstore k1k2 k1 k2 // k1 k2去并集,并且存儲(chǔ)在k1k2鍵中
(integer) 6
127.0.0.1:6379> smembers k1k2 // 取出鍵為k1k2的值
1) "b"
2) "a"
3) "f"
4) "e"
5) "d"
6) "c"
127.0.0.1:6379> sdiff k1 k2 // 取差集,從k1中取出k2沒有的
1) "a"
2) "b"
127.0.0.1:6379> sdiff k2 k1 // 取差集,從k2中取出k1沒有的
1) "f"
2) "e"

④排行榜,(zset有序集合)

127.0.0.1:6379> zadd key1 100 user1 80 user2 99 user3 10 user4 9 user5
(integer) 5
127.0.0.1:6379> zrange key1 0 -1 // 按分?jǐn)?shù)從小到大排序
1) "user5"
2) "user4"
3) "user2"
4) "user3"
5) "user1"
127.0.0.1:6379> zrange key1 0 -1 withscores // 按分?jǐn)?shù)從小到大排序,帶上分?jǐn)?shù)
 1) "user5"
 2) "9"
 3) "user4"
 4) "10"
 5) "user2"
 6) "80"
 7) "user3"
 8) "99"
 9) "user1"
10) "100"
127.0.0.1:6379> zrank key1 user1 // 取出user1的排名,第5名
(integer) 4
127.0.0.1:6379> zrank key1 user5 // 取出user5的排名,第1名
(integer) 0
127.0.0.1:6379> zscore key1 user5 // 取出user5的分?jǐn)?shù)
"9"
127.0.0.1:6379> zrevrange key1 0 -1 // 按分?jǐn)?shù)從大到小排序
1) "user1"
2) "user3"
3) "user2"
4) "user4"
5) "user5"
127.0.0.1:6379> zincrby key1 5 user2 // 給user2加上5分
"85"
127.0.0.1:6379> zrange key1 0 -1 withscores
 1) "user5"
 2) "9"
 3) "user4"
 4) "10"
 5) "user2"
 6) "85"
 7) "user3"
 8) "99"
 9) "user1"
10) "100"
127.0.0.1:6379> zincrby key1 -2 user2 // 給user2減2分
"83"

⑤點(diǎn)贊/收藏功能 (zset有序集合)

-- key:  love_user{userId}
-- score:當(dāng)前時(shí)間戳,可按時(shí)間排序
-- value:  被點(diǎn)贊/收藏的id

如:用戶id為1的用戶,在不同時(shí)間段點(diǎn)贊了id為2,5,4的xx
127.0.0.1:6379> zAdd love_user1 1641190850 2
(integer) 1
127.0.0.1:6379> zAdd love_user1 1641196800 5
(integer) 1
127.0.0.1:6379> zAdd love_user1 1641283200 4
(integer) 1

判斷是否已經(jīng)點(diǎn)贊
127.0.0.1:6379> zScore love_user1 2
"1641190850"

按點(diǎn)贊時(shí)間倒序排列,取出10條
127.0.0.1:6379> zRevRangeByScore love_user1 1641283200 0 WITHSCORES LIMIT 0 10
1) "4"
2) "1641283200"
3) "5"
4) "1641196800"
5) "2"
6) "1641190850"

取消點(diǎn)贊
127.0.0.1:6379> zRem love_user1 5
(integer) 1

查看所有點(diǎn)贊的id
127.0.0.1:6379> zRange love_user1 0 -1
1) "2"
2) "4"

總的點(diǎn)贊數(shù)
127.0.0.1:6379> zCard love_user1
(integer) 2

未完待續(xù).......

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容