Redis基礎類型常用操作指令
Redis概念
REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的key-value存儲系統。
Redis是一個開源的使用ANSI C語言編寫、遵守BSD協定、支援網絡、可基于記憶體亦可持久化的日志型、Key-Value資料庫,并提供多種語言的API。
它通常被稱為資料結構伺服器,因為值(value)可以是 字元串(String), 哈希(Hash), 清單(list), 集合(sets) 和 有序集合(sorted sets)等類型。
Redis特征
資料間沒有必然的聯系
内部采用單線程機制進行工作
高性能
多資料類型支援
字元串類型 String
清單類型 List
散列類型 Map
集合類型 Set
有序集合類型 SortedSet
持久化支援
Redis應用場景
為熱點資料加速查詢;如:熱點商品、熱點新聞、熱點資訊等高通路量資訊。
任務隊列;如:秒殺、搶購、購票等。
即時資訊查詢;如:排行榜等。
時效性資訊控制;如:驗證碼、投票控制等。
分布式資料共享;如:分布式架構中的session等。
消息隊列
分布式鎖
Redis基礎資料類型之: 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的設定約定
與資料庫中的表-主鍵-字段一一對應

Redis基礎資料類型之: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存儲的鍵值對上限為
個鍵值對
hash類型十分貼近對象的存儲形式,并且可以靈活删除對象屬性。但hash設計初衷并不是為了存儲大量對象而設計的,切記不可濫用,更不可将hash作為對象清單使用
hgetall操作可以擷取全部屬性,如果内部field過多,周遊整體資料效率會很低,有可能會成為資料通路瓶頸
應用場景
電商網站購物車設計實作
Redis基礎資料類型之: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,第二頁及更多的資料資訊通過資料庫進行查詢加載
Redis基礎資料類型之: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中存儲值的空間
Redis基礎資料類型: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 ...]