共計 3658 個字符,預計需要花費 10 分鐘才能閱讀完成。
Redis 基礎類型及常用操作、命令有哪些,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
概念:Redis 是用 C 語言開發的一個開源的高性能鍵值對數據庫。
特征:
數據間沒有必然的聯系
內部采用單線程機制進行工作
高性能
多數據類型支持字符串類型 String 列表類型 List 散列類型 Map 集合類型 Set 有序集合類型 SortedSet
持久化支持
應用場景
為熱點數據加速查詢; 如:熱點商品、熱點新聞、熱點資訊等高訪問量信息。
任務隊列; 如:秒殺、搶購、購票等。
即時信息查詢; 如:排行榜等。
時效性信息控制; 如:驗證碼、投票控制等。
分布式數據共享; 如:分布式架構中的 session 等。
消息隊列
分布式鎖
基礎數據類型之: String
單個 string 類型的存儲空間為 512MB
string 基本操作
添加或修改數據
set key value
獲取數據
get key
刪除數據
del key
設置過期時間 (默認單位為秒)
expire key second
追加信息到初始 value 后邊
append key value
添加 / 修改多個數據
mset key1 value1 key2 value2...
獲取多個數據
mget key
1 key2 ...
獲取字符串長度
strlen key
設置 key 的生命周期 控制生命周期
setex key seconds value (秒) psetex key millisexxonds value (毫秒)
key 的設置約定與數據庫中的表 - 主鍵 - 字段一一對應表名主鍵名主鍵值字段名 eg1orderid443523454nameeg2equireid435432543typeeg3newsid45435454title
基礎數據類型之:Hash
存儲需求:對一系列存儲的數據進行編排,方便管理,典型應用存儲對象信息
存儲結構:一個存儲空間存儲多個鍵值對數據
hash 類型:底層使用哈希表結構實現數據存儲
hash 存儲結構優化
如果 field 數量較少,存儲結構優化為類數組結構
如果 field 數量較多,存儲結構使用 HashMap 結構
hash 類型基本操作
添加 / 修改數據
hset key field value
獲取數據
hget key
field hgetall key
刪除數據
hdel key
field [field2 ...]
添加或刪除多個數據
hmset key field1 value1 field2 value2 ...
獲取多個數據
hmget key
field1 field2 ...
獲取 hash 表中的字段的數量
hlen key
獲取 hash 表中是否存在指定的字段
hexists key field
獲取哈希表中所用的字段名或字段值
hkeys keyhvalues key
設置指定字段的數值數據增加指定范圍的值
hincrby key field increment hincrbyfloat key field increment
如果 key 值下的 field 存在則不做操作 不存在則添加進去
hsetnx key field value
hash 類型數據操作的注意事項
hash 類型下的 value 只能存儲字符串,不允許存儲其他數據類型,不存在嵌套現象,如果數據未獲取到,對應的值為 (nil)
每個 hash 存儲的鍵值對上限為 $$2^{32}-1$$ 個鍵值對
hash 類型十分貼近對象的存儲形式,并且可以靈活刪除對象屬性。但 hash 設計初衷并不是為了存儲大量對象而設計的,切記不可濫用,更不可將 hash 作為對象列表使用
hgetall 操作可以獲取全部屬性,如果內部 field 過多,遍歷整體數據效率會很低,有可能會成為數據訪問瓶頸
應用場景
電商網站購物車設計實現
基礎數據類型之:list
數據存儲需求:存儲多個數據,并對數據進入存儲 Jon 關鍵的順序進行區分
需要的存儲結構:一個存儲空間存儲多個數據,并且數據可以體現進入順序
list 類型:保存多個數據,底層使用雙向鏈表存儲結構實現
list 類型是雙向鏈表存儲的
list 基本操作
添加 / 修改數據
lpush key value1 value2 [value3] ... // 從 list 鏈表左側添加 rpush key value1 value2 [value3] ... // 從 list 右側添加
獲取數據
lrange key start stop // 指定鏈表起始結束位置中的 value // 在獲取未知長的的 list 類型的時候,想查看所有的 value 可以使用 - 1 表示倒數第一個 lrange key start -1 lindex key index // 獲取鏈表中指定位置的值 llen key // 獲取鏈表的長度
獲取并移除數據
lpop key rpop key
規定時間內獲取并移除數據 (阻塞式數據獲取)
blpop key1 [key2] timeout // 指定時間內取出并移除 key 值對應的 value,若 timeout 超時仍未取出則返回空值(nil) 若本來沒有 其他客戶端在等待的時候添加了這個 key 的 value 則做操作 任務隊列 brpop key1 [key2] timeout
移除指定數據
lrem key count value
list 類型數據操作注意事項
list 中保存的數據都是 string 類型的,數據總容量有限最多 2^32- 1 個元素
list 具有索引概念,但操作數據時通常以隊列的形式進行入隊出隊操作,或以棧的形式進行入棧出棧操作
獲取全部操作結束數據的索引設置為 -1
list 可以對數據進行分頁操作,通常第一頁的信息來自 list,第二頁及更多的數據信息通過數據庫進行查詢加載
基礎數據類型之:set
存儲需求:存儲大量的數據,在查詢方面提供更高的效率
存儲結構:能夠保存大量的數據,高效的內部存儲機制,便于查詢
set 類型:與 hash 存儲結構完全相同,僅存儲鍵,不存儲值 (nil), 并且值不允許為空
set 存儲結構是 string 類型的無序集合,內部存儲時 hash 存儲結構,因此添加、查找、刪除的復雜度都是 O(1)
set 基本操作
添加不重復的數據
sadd key value
獲取存儲的所有數據
smembers key
刪除數據
strem key member1 [member2]
獲取集合數據總量
scard key
判斷集合中是否包含指定數據
sismember key member
隨機獲取集合中指定數量的數據
srandmember key [count]
隨機獲取集合中某個數據并將該數據移出集合
apop key
兩個集合的交、并、差集
sinter key1 [key2] sunion key1 [key2] adiff key1 [key2]
求兩個集合的交、并、差集并存儲到指定集合中
sinterstore destination key1 [key2] sunionstore destination key1 [key2] sdiffstore destination key1 [key2]
將指定數據從原始集合中移動到目標集合中
smove source destination member
注意事項
set 類型不允許有重復數據,如果添加的數據在 set 中已存在,將只保留一份
set 雖然與 hash 存儲結構相同,但無法啟用 hash 中存儲值的空間
基礎數據類型:sortedSet
存儲需求:數據排序有利于數據的展示效果,需要提供一種可以根據自身特征進行排序的方式
存儲結構:可以保存排序的數據
存儲類型:在 set 的存儲結構上添加可排序字段
基本操作
添加數據
zadd key scorel member [score2 member2]
獲取全部數據
zrange key start stop [witchscores]zrevrange key star stop [witchscores]
刪除數據
zrem key member [member ...]
按條件查詢數據
zrangebyscore key min max [withscores] [limit] zrevrangebyscore key max min [withscores]
條件刪除數據
zremrangebyrank key start stop //start stop 表示索引的開始結束位置 zremrangebyscore key min max //min max 表示排序的最小到最大位置
獲取集合數據數量
zcard key zcount key min max
集合交、并操作
zinterstore destination numkeys key [key ...] zunionstore destination key [key ...]
看完上述內容,你們掌握 Redis 基礎類型及常用操作、命令有哪些的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注丸趣 TV 行業資訊頻道,感謝各位的閱讀!