redis 除了這 5 種資料型別之外,還有 bitmaps、hyperloglogs、streams 等。這是最簡單的型別,就是普通的 set 和 get,做簡單的 kv 快取。
set college szu
複製**
這個是類似 map 的一種結構,這個一般就是可以將結構化的資料,比如乙個物件(前提是這個物件沒巢狀其他的物件)給快取在 redis 裡,然後每次讀寫快取的時候,可以就操作 hash 裡的某個字段。
hset person name bingo
hset person age 20
hset person id 1
hget person name
(person = )
複製**
lists 是有序列表,這個可以玩兒出很多花樣。
比如可以通過 lrange 命令,讀取某個閉區間內的元素,可以基於 list 實現分頁查詢,這個是很棒的乙個功能,基於 redis 實現簡單的高效能分頁,可以做類似微博那種下拉不斷分頁的東西,效能高,就一頁一頁走。
# 0開始位置,-1結束位置,結束位置為-1時,表示列表的最後乙個位置,即檢視所有。
lrange mylist 0 -1
複製**
比如可以搞個簡單的訊息佇列,從 list 頭懟進去,從 list 尾巴那裡弄出來。
lpush mylist 1
lpush mylist 2
lpush mylist 3 4 5
# 1rpop mylist
複製**
sets 是無序集合,自動去重。
直接基於 set 將系統裡需要去重的資料扔進去,自動就給去重了,如果你需要對一些資料進行快速的全域性去重,你當然也可以基於 jvm 記憶體裡的 hashset 進行去重,但是如果你的某個系統部署在多台機器上呢?得基於 redis 進行全域性的 set 去重。
可以基於 set 玩兒交集、並集、差集的操作,比如交集吧,可以把兩個人的粉絲列表整乙個交集,看看倆人的共同好友是誰?對吧。
把兩個大 v 的粉絲都放在兩個 set 中,對兩個 set 做交集。
#-------操作乙個set-------
# 新增元素
sadd myset 1
# 檢視全部元素
smembers myset
# 判斷是否包含某個值
sismember myset 3
# 刪除某個/些元素
srem myset 1
srem myset 2 4
# 檢視元素個數
scard myset
# 隨機刪除乙個元素
spop myset
#-------操作多個set-------
# 將乙個set的元素移動到另外乙個set
smove yourset myset 2
# 求兩set的交集
sinter yourset myset
# 求兩set的並集
sunion yourset myset
# 求在yourset中而不在myset中的元素
sdiff yourset myset
複製**
sorted sets 是排序的 set,去重但可以排序,寫進去的時候給乙個分數,自動根據分數排序。
zadd board 85 zhangsan
zadd board 72 lisi
zadd board 96 wangwu
zadd board 63 zhaoliu
# 獲取排名前三的使用者(預設是公升序,所以需要 rev 改為降序)
zrevrange board 0 3
# 獲取某使用者的排名
zrank board zhaoliu
複製**
Redis資料型別及使用場景
wqtech閱讀 2936 摘要 redis相比其它的kv資料庫,其一大特點是支援豐富的資料型別.它一共支援5種資料型別,下面逐一介紹這5種資料型別及其使用場景.redis相比其它的kv資料庫,其一大特點是支援豐富的資料型別。它一共支援5種資料型別,下面逐一介紹這5種資料型別及其使用場景和內部實現方...
Redis資料型別及使用場景
redis支援常見的資料型別,現在是被廣泛用在各大公司的內部,它可以做的東西很多,不過要先了解下他提供的基本資料型別與常見操作。接下來一起看看把。最基礎的資料型別,首先key是字串型別,其它的資料型別都是在字串的基礎之上構建的。set命令 批量設定和獲取命令,在操作多個key的時候可以節省網路傳輸時...
Redis的資料型別及使用場景
儲存的時候key和value都是string,value支援string hash list set zset等資料結構。redis內部的key value通過乙個redisobject物件來儲存,type表示value的型別 string等 encoding表示儲存方式 raw int等 結構 k...