概念: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 key1 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 key hvalues 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 ...]