概念:Redis是用C語言開發的一個開源的高性能鍵值對數據庫。redis
特徵:shell
單個string類型的存儲空間爲512MB數據庫
添加或修改數據數組
set key value
獲取數據session
get key
刪除數據架構
del key
設置過時時間(默認單位爲秒)app
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的設置約定
與數據庫中的表-主鍵-字段一一對應
表名 | 主鍵名 | 主鍵值 | 字段名 | |
---|---|---|---|---|
eg1 | order | id | 443523454 | name |
eg2 | equire | id | 435432543 | type |
eg3 | news | id | 45435454 | title |
- 存儲需求: 對一系列存儲的數據進行編排,方便管理,典型應用存儲對象信息
- 存儲結構:一個存儲空間存儲多個鍵值對數據
- hash類型:底層使用哈希表結構實現數據存儲
hash存儲結構優化
- 若是field數量較少,存儲結構優化爲類數組結構
- 若是field數量較多,存儲結構使用HashMap結構
添加/修改數據
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類型下的value只能存儲字符串,不容許存儲其餘數據類型,不存在嵌套現象,若是數據未獲取到,對應的值爲(nil)
每一個hash存儲的鍵值對上限爲
$$
2^{32}-1
$$
個鍵值對
hash類型十分貼近對象的存儲形式,而且能夠靈活刪除對象屬性。但hash設計初衷並非爲了存儲大量對象而設計的,切記不可濫用,更不可將hash做爲對象列表使用
hgetall操做能夠獲取所有屬性,若是內部field過多,遍歷總體數據效率會很低,有可能會成爲數據訪問瓶頸
- 數據存儲需求:存儲多個數據,並對數據進入存儲Jon關鍵的順序進行區分
- 須要的存儲結構:一個存儲空間存儲多個數據,而且數據能夠體現進入順序
- 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
- 存儲需求:存儲大量的數據,在查詢方面提供更高的效率
- 存儲結構:可以保存大量的數據,高效的內部存儲機制,便於查詢
- set類型:與hash存儲結構徹底相同,僅存儲鍵,不存儲值(nil),而且值不容許爲空
set存儲結構是string類型的無序集合,內部存儲時hash存儲結構,所以添加、查找、刪除的複雜度都是O(1)
添加不重複的數據
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中存儲值的空間
存儲需求:數據排序有利於數據的展現效果,須要提供一種能夠根據自身特徵進行排序的方式
存儲結構:能夠保存排序的數據
存儲類型:在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 ...]