redis 五種資料型別和應用場景

2021-09-29 20:05:48 字數 3801 閱讀 1984

string型別

string為最簡單型別,乙個key對應乙個value

set mykey 「wangzai」 ##設定key,第二次賦值會直接覆蓋之前的

setnx mykey 「wangzai」 ## 如果mykey存在,則不改變,如果不存在,則建立賦值

get mykey ##獲取key的值

setex key1 10 1 ##給key1設定過期時間為10s,值為1

mset key1 value1 key2 value2 ##設定多個key

mget key1 key2 ##獲取多個key的值

list型別

列表型別是用來儲存多個有序的字串,列表中的每個字串成為元素(element),乙個列表最多可以儲存

2的32次方-1個元素,在redis中,可以隊列表兩端插入(pubsh)和彈出(pop),還可以獲取指定範圍的元素

列表、獲取指定索引下表的元素等,列表是一種比較靈活的資料結構,它可以充當棧和佇列的角色,

在實際開發中有很多應用場景。

優點:1.列表的元素是有序的,這就意味著可以通過索引下標獲取某個或某個範圍內的元素列表。

2.列表內的元素是可以重複的。

list是乙個鍊錶結構,主要功能是push、pop以及獲取乙個範圍的所有值等。

使用list結構,可以輕鬆實現最新訊息排行,另乙個應用是訊息佇列,可以利用list的push操作,將任務存在list中,然後工作執行緒再用pop操作將任務取出進行執行。(先進後出)

lpush list1 「wangzai」 ##在列表中加入乙個元素

lrange list1 0 -1 ##檢視list1裡面的所有元素

lpop list1 ##取出list1最新的元素

linsert list1 before 「wangzai」 「doubi」 ##在值為"wangzai"的前面插入乙個元素為"doubi"

lset list1 3 「hehe」 ##把第五個元素修改為"hehe"

lindex list1 0 ##檢視第乙個元素

llen list1 ##檢視列表中有多少元素

使用場景:

訊息佇列: redis的lpush+brpop命令組合即可實現阻塞佇列,生產者客戶端是用lupsh從列表左側插入元素,

多個消費者客戶端使用brpop命令阻塞時的「搶」列表尾部的元素,多個客戶端保證了消費的負載均衡

和高可用性

訊息佇列模型↑

集合型別也是用來儲存多個字串的元素,但和列表不同的是集合中不允許有重複的元素,並且集合中的元素是

無序的,不能通過索引下標獲取元素,redis除了支援集合內的增刪改查,同時還支援多個集合取交集、並集、

差集,並合理的使用好集合型別,能在實際開發中解決很多實際問題。

set是集合,對集合操作有新增刪除元素,有對多個集合求交並差等操作。在微博應用中,可以將乙個使用者關注的所有人放在乙個集合裡,將所有粉絲放在乙個集合裡,因為redis為集合提供了求交集、並集、差集等操作,就可以方便的實現如共同關注、共同喜好等功能。

複製**

sadd set1 a b c d ## 建立集合set1並設定值

smembers set1 ## 檢視集合set1的值

srem set1 a b ## 刪除set1的值

spop set1 ## 隨機取出乙個元素並刪除

sinter set1 set2 ## 交集

sinterstore set1 set2 set3 ## 將交集儲存到set3

sunion set1 set2 ## 並集

sunionstore set1 set2 set3 ## 把並集儲存到set3

sdiff set1 set2 ## 差集

sdiffstore set1 set2 set3 ## 把差集儲存到set3

sismember set1 c ## 判斷乙個元素是否屬於乙個集合

srandmember set1 ## 隨機取出乙個元素,但不刪除

使用場景:

標籤(tag):集合型別比較典型的使用場景,如乙個使用者對娛樂、體育比較感興趣,另乙個可能對新聞感興

趣,這些興趣就是標籤,有了這些資料就可以得到同一標籤的人,以及使用者的共同愛好的標籤,

這些資料對於使用者體驗以及曾強使用者粘度比較重要。

(使用者和標籤的關係維護應該放在乙個事物內執行,防止部分命令失敗造成資料不一致)

sadd=tagging(標籤)

spop/srandmember=random item(生成隨機數,比如**)

sadd+sinter=social graph(社交需求)

sorted set型別

有序集合和集合有著必然的聯絡,他保留了集合不能有重複成員的特性,但不同得是,有序集合中的元素是可以

排序的,但是它和列表的使用索引下標作為排序依據不同的是,它給每個元素設定乙個分數,作為排序的依據。

(有序集合中的元素不可以重複,但是csore可以重複,就和乙個班裡的同學學號不能重複,但考試成績可以相

同)。列表、集合、有序集合三者的異同點

sorted set是有序集合,比set多了乙個權重引數score,使得集合元素能夠按score進行有序排列。

例如儲存乙個班級同學的成績,其集合value可以是同學的學號,而score可以是其考試的得分,這樣在資料插入集合的時候就進行了排序。

zadd zset1 1 a ## 增加乙個集合zset1,score為1,member為a

zrange zset1 0 -1 ## 按score公升序輸出member

zrange zset1 0 -1 withscores ## 帶上分值

zrem zset1 a ## 刪除指定元素

zrank zset1 a ## 返回元素的索引值,索引從0開始

zrevrange zset1 0 -1 ## score降序輸出member

zcard zset1 ## 返回集合中所有元素的個數

zcount zset1 1 10 ## 返回分值範圍1-10的元素個數

zrangebyscore zset1 1 10 ## 返回分值範圍1-10的元素

zremrangebyscore zset1 1 10 ## 刪除分值範圍1-10的元素

hash型別

在redis中雜湊型別是指鍵本身又是一種鍵值對結構,如 value=,…}

把一些結構化的資訊打包成hashmap,在客戶端序列化後儲存為乙個字串的值(一般為json格式),比如使用者姓名、年齡、性別等

複製**

hset hash1 name wangzai ## 建立hash (hset name key value)

hget hash1 name ## 獲取field值 hget name key

hgetall hash1 ## 獲取hash1中所有的key和value

hmset hash2 name wangzai age 26 job it ## 批量建立鍵值對

hmget hash2 name age job ## 批量獲取field值

hdel hash2 job ## 刪除指定field

hkeys hash2 ## 列印所有的key

hvals hash2 ## 列印所有的value

hlen hash2 ## 檢視hash2有幾個field

使用場景:

雜湊結構相對於字串序列化快取資訊更加直觀,並且在更新操作上更加便捷。

所以常常用於使用者資訊等管理,但是雜湊型別和關係型資料庫有所不同,雜湊型別是稀疏的,

而關係型資料庫是完全結構化的,關係型資料庫可以做複雜的關係查詢,而redis去模擬關係型複雜查詢

開發困難,維護成本高。

redis 五種資料型別和應用場景

字串型別是redis最基礎的資料結構,首先鍵是字串型別,而且其他幾種結構都是在字串型別基礎上構建的,所以字串型別能為其他四種資料結構的學習尊定基礎。字串型別實際上可以是字串 但最大不能超過512m。快取功能 字串最經典的使用場景,redis最為快取層,mysql作為儲存層,絕大部分請求資料都是 re...

redis 五種資料型別和應用場景(一)

一 字串型別和使用場景 字串型別是redis最基礎的資料結構,首先鍵是字串型別,而且其他幾種結構都是在字串型別基礎上構建的,所以字串型別能為其他四種資料結構的學習尊定基礎。字串型別實際上可以是字串 簡單的字串 複雜 快取功能 字串最經典的使用場景,redis最為快取層,mysql作為儲存層,絕大部分...

Redis 五種資料型別及其應用場景

redis 資料都是 k v 模型,本身就是hashmap 一種形式,器豐富的資料型別,應該場景特別多。redis 可使用redis cli help string 檢視方法 一,string 1,簡單的 key value 2,計數器 設定數值時,incr 加1 decr 減1。數值計算 3,二進...