程序員 做網(wǎng)站 微信公眾號 賺錢寧波seo推廣費用
目錄
Redis數(shù)據(jù)結(jié)構(gòu)介紹
Redis通用命令
KEYS
DEL
EXISTS
EXPIRE
String類型
Key的層級格式
Hash類型
List類型
Set類型
SortedSet類型
Redis數(shù)據(jù)結(jié)構(gòu)介紹
Redis是一個key-value的數(shù)據(jù)庫,key一般是String數(shù)據(jù)庫,value的類型多種多樣
可以通過help命令查看命令:
Redis通用命令
通用指令是部分?jǐn)?shù)據(jù)類型都可以使用的指令,常見的有:
- KEYS:查看符合模板的所有key
- DEL:刪除一個指定的key
- EXISTS:給一個key設(shè)置有效期,有效期到期時該key會被自動刪除
- TTL:查看一個key的剩余有效期
KEYS
在生產(chǎn)環(huán)境下,不推薦使用KEYS命令,因為這個命令在key過多的情況下,效率不高
127.0.0.1:6379> keys *
1) "name"
2) "age"
127.0.0.1:6379># 查詢以a開頭的key
127.0.0.1:6379> keys a*
1) "age"
127.0.0.1:6379>
DEL
127.0.0.1:6379> help delDEL key [key ...]summary: Delete a keysince: 1.0.0group: generic127.0.0.1:6379> del name #刪除單個
(integer) 1 #成功刪除1個127.0.0.1:6379> keys *
1) "age"127.0.0.1:6379> MSET k1 v1 k2 v2 k3 v3 #批量添加數(shù)據(jù)
OK127.0.0.1:6379> keys *
1) "k3"
2) "k2"
3) "k1"
4) "age"127.0.0.1:6379> del k1 k2 k3 k4
(integer) 3 #此處返回的是成功刪除的key,由于redis中只有k1,k2,k3 所以只成功刪除3個,最終返回
127.0.0.1:6379>127.0.0.1:6379> keys * #再查詢?nèi)康膋ey
1) "age" #只剩下一個了
127.0.0.1:6379>
EXISTS
127.0.0.1:6379> help EXISTSEXISTS key [key ...]summary: Determine if a key existssince: 1.0.0group: generic127.0.0.1:6379> exists age
(integer) 1127.0.0.1:6379> exists name
(integer) 0
EXPIRE
127.0.0.1:6379> expire age 10
(integer) 1127.0.0.1:6379> ttl age
(integer) 8127.0.0.1:6379> ttl age
(integer) 6127.0.0.1:6379> ttl age
(integer) -2127.0.0.1:6379> ttl age
(integer) -2 #當(dāng)這個key過期了,那么此時查詢出來就是-2 127.0.0.1:6379> keys *
(empty list or set)127.0.0.1:6379> set age 10 #如果沒有設(shè)置過期時間
OK127.0.0.1:6379> ttl age
(integer) -1 # ttl的返回值就是-1
String類型
String類型,也就是字符串類型,是Redis中最簡單的存儲類型
其value是字符串,根據(jù)字符串的格式不同,可以分為三類:
- string:普通字符串
- int:整數(shù)類型,可以做自增、自減操作
- float:浮點類型,可以做自增、自減操作
String常見的命令有:
-
SET:添加或者修改已經(jīng)存在的一個String類型的鍵值對
-
GET:根據(jù)key獲取String類型的value
-
MSET:批量添加多個String類型的鍵值對
-
MGET:根據(jù)多個key獲取多個String類型的value
-
INCR:讓一個整型的key自增1
-
INCRBY:讓一個整型的key自增并指定步長,例如:incrby num 2 讓num值自增2
-
INCRBYFLOAT:讓一個浮點類型的數(shù)字自增并指定步長
-
SETNX:添加一個String類型的鍵值對,前提是這個key不存在,否則不執(zhí)行
-
SETEX:添加一個String類型的鍵值對,并且指定有效期
SET和GET
如果key不存在則是新增,存在則是修改
127.0.0.1:6379> set name Rose //原來不存在
OK127.0.0.1:6379> get name
"Rose"127.0.0.1:6379> set name Jack //原來存在,就是修改
OK127.0.0.1:6379> get name
"Jack"
MSET和MGET
127.0.0.1:6379> MSET k1 v1 k2 v2 k3 v3
OK127.0.0.1:6379> MGET name age k1 k2 k3
1) "Jack" //之前存在的name
2) "10" //之前存在的age
3) "v1"
4) "v2"
5) "v3"
INCR、INCRBY和DECR
127.0.0.1:6379> get age
"10"127.0.0.1:6379> incr age //增加1
(integer) 11127.0.0.1:6379> get age //獲得age
"11"127.0.0.1:6379> incrby age 2 //一次增加2
(integer) 13 //返回目前的age的值127.0.0.1:6379> incrby age 2
(integer) 15127.0.0.1:6379> incrby age -1 //也可以增加負(fù)數(shù),相當(dāng)于減
(integer) 14127.0.0.1:6379> incrby age -2 //一次減少2個
(integer) 12127.0.0.1:6379> DECR age //相當(dāng)于 incr 負(fù)數(shù),減少正常用法
(integer) 11127.0.0.1:6379> get age
"11"
SETNX
127.0.0.1:6379> help setnxSETNX key valuesummary: Set the value of a key, only if the key does not existsince: 1.0.0group: string127.0.0.1:6379> set name Jack //設(shè)置名稱
OK
127.0.0.1:6379> setnx name lisi //如果key不存在,則添加成功
(integer) 0
127.0.0.1:6379> get name //由于name已經(jīng)存在,所以lisi的操作失敗
"Jack"
127.0.0.1:6379> setnx name2 lisi //name2 不存在,所以操作成功
(integer) 1
127.0.0.1:6379> get name2
"lisi"
SETEX
127.0.0.1:6379> setex name 10 jack
OK127.0.0.1:6379> ttl name
(integer) 8127.0.0.1:6379> ttl name
(integer) 7127.0.0.1:6379> ttl name
(integer) 5
Key的層級格式
如果需要存儲用戶和商品信息到Redis,有一個用戶id是1,一個商品id也是1,此時如果使用id作為key就會沖突
解決:通過給key添加前綴加以區(qū)分
Redis的key允許有多個單詞形成層級結(jié)構(gòu),多個單詞之間用‘:’隔開,格式如下:
例如項目名稱是heima,有user和product兩種不同類型的數(shù)據(jù),定義key如下:
-
user相關(guān)的key:heima:user:1
-
product相關(guān)的key:heima:product:1
如果value是一個Java對象,例如User對象,可以將對象序列化為JSON字符串后存儲:
KEY | VALUE |
---|---|
heima:user:1 | {"id":1, "name": "Jack", "age": 21} |
heima:product:1 | {"id":1, "name": "小米11", "price": 4999} |
在可視化界面中,Redis會以層級結(jié)構(gòu)來進行存儲,獲取數(shù)據(jù)更方便
Hash類型
Hash類型,也叫散列,其value是一個無序字典,類似于Java中的HashMap結(jié)構(gòu)
String結(jié)構(gòu)是將對象序列化為JSON字符串后存儲,當(dāng)需要修改對象某個字段時很不方便:
Hash結(jié)構(gòu)可以將對象中的每個字段獨立存儲,可以針對單個字段做CRUD:
Hash類型的常見命令:
-
HSET key field value:添加或者修改hash類型key的field的值
-
HGET key field:獲取一個hash類型key的field的值
-
HMSET:批量添加多個hash類型key的field的值
-
HMGET:批量獲取多個hash類型key的field的值
-
HGETALL:獲取一個hash類型的key中的所有的field和value
-
HKEYS:獲取一個hash類型的key中的所有的field
-
HINCRBY:讓一個hash類型key的字段值自增并指定步長
-
HSETNX:添加一個hash類型的key的field值,前提是這個field不存在,否則不執(zhí)行
HSET和HGET
127.0.0.1:6379> HSET heima:user:3 name Lucy//大key是 heima:user:3 小key是name,小value是Lucy
(integer) 1
127.0.0.1:6379> HSET heima:user:3 age 21// 如果操作不存在的數(shù)據(jù),則是新增
(integer) 1
127.0.0.1:6379> HSET heima:user:3 age 17 //如果操作存在的數(shù)據(jù),則是修改
(integer) 0
127.0.0.1:6379> HGET heima:user:3 name
"Lucy"
127.0.0.1:6379> HGET heima:user:3 age
"17"
HMSET和HMGET
127.0.0.1:6379> HMSET heima:user:4 name HanMeiMei
OK
127.0.0.1:6379> HMSET heima:user:4 name LiLei age 20 sex man
OK
127.0.0.1:6379> HMGET heima:user:4 name age sex
1) "LiLei"
2) "20"
3) "man"
HGETALL
127.0.0.1:6379> HGETALL heima:user:4
1) "name"
2) "LiLei"
3) "age"
4) "20"
5) "sex"
6) "man"
HKEYS和HVALS
127.0.0.1:6379> HKEYS heima:user:4
1) "name"
2) "age"
3) "sex"
127.0.0.1:6379> HVALS heima:user:4
1) "LiLei"
2) "20"
3) "man"
HINCRBY
127.0.0.1:6379> HINCRBY heima:user:4 age 2
(integer) 22
127.0.0.1:6379> HVALS heima:user:4
1) "LiLei"
2) "22"
3) "man"
127.0.0.1:6379> HINCRBY heima:user:4 age -2
(integer) 20
HSETNX
127.0.0.1:6379> HSETNX heima:user4 sex woman
(integer) 1
127.0.0.1:6379> HGETALL heima:user:3
1) "name"
2) "Lucy"
3) "age"
4) "17"
127.0.0.1:6379> HSETNX heima:user:3 sex woman
(integer) 1
127.0.0.1:6379> HGETALL heima:user:3
1) "name"
2) "Lucy"
3) "age"
4) "17"
5) "sex"
6) "woman"
List類型
Redis中的List類型與Java中的LinkedList類似,可以看做是一個雙向鏈表結(jié)構(gòu),既可以支持正向檢索,也可以支持反向檢索
特征:
-
有序
-
元素可以重復(fù)
-
插入和刪除快
-
查詢速度一般
常用來存儲一個有序數(shù)據(jù),如:朋友圈點贊列表、評論列表
List的常見命令:
-
LPUSH key element ... :向列表左側(cè)插入一個或多個元素
-
LPOP key:移除并返回列表左側(cè)的第一個元素,沒有則返回nil
-
RPUSH key element ... :向列表右側(cè)插入一個或多個元素
-
RPOP key:移除并返回列表右側(cè)的第一個元素
-
LRANGE key star end:返回一段角標(biāo)范圍內(nèi)的所有元素
-
BLPOP和BRPOP:與LPOP和RPOP類似,只不過在沒有元素時等待指定時間,而不是直接返回nil
LPUSH和RPUSH
127.0.0.1:6379> LPUSH users 1 2 3
(integer) 3
127.0.0.1:6379> RPUSH users 4 5 6
(integer) 6
LPOP和RPOP
127.0.0.1:6379> LPOP users
"3"
127.0.0.1:6379> RPOP users
"6"
LRANGE
127.0.0.1:6379> LRANGE users 1 2
1) "1"
2) "4"
思考:
- 如何利用List模擬一個棧?
? ? ? ?入口和出口在同一邊?
- 如何利用List模擬一個隊列?
? ? ? ?入口和出口在不同邊
- 如何利用List模擬一個阻塞隊列?
? ? ? ?入口和出口在不同邊
? ? ? ?出隊時采用BLPOP或BRPOP
Set類型
Redis的Set結(jié)構(gòu)與Java中的HashSet類似,可以看做是一個value為null的HashMap
特征:
-
無序
-
元素不可重復(fù)
-
查找快
-
支持交集、并集、差集等功能
Set類型的常見命令:
-
SADD key member ... :向set中添加一個或多個元素
-
SREM key member ... : 移除set中的指定元素
-
SCARD key: 返回set中元素的個數(shù)
-
SISMEMBER key member:判斷一個元素是否存在于set中
-
SMEMBERS:獲取set中的所有元素
-
SINTER key1 key2 ... :求key1與key2的交集
-
SDIFF key1 key2 ... :求key1與key2的差集
-
SUNION key1 key2 ..:求key1和key2的并集
127.0.0.1:6379> sadd s1 a b c
(integer) 3
127.0.0.1:6379> smembers s1
1) "c"
2) "b"
3) "a"
127.0.0.1:6379> srem s1 a
(integer) 1127.0.0.1:6379> SISMEMBER s1 a
(integer) 0127.0.0.1:6379> SISMEMBER s1 b
(integer) 1127.0.0.1:6379> SCARD s1
(integer) 2
案例:
將下列數(shù)據(jù)用Redis的Set集合來存儲:
-
張三的好友有:李四.王五.趙六
-
李四的好友有:王五.麻子.二狗
-
利用Set的命令實現(xiàn)下列功能:
-
計算張三的好友有幾人
-
計算張三和李四有哪些共同好友
-
查詢哪些人是張三的好友卻不是李四的好友
-
查詢張三和李四的好友總共有哪些人
-
判斷李四是否是張三的好友
-
判斷張三是否是李四的好友
-
將李四從張三的好友列表中移除
127.0.0.1:6379> SADD zs lisi wangwu zhaoliu
(integer) 3127.0.0.1:6379> SADD ls wangwu mazi ergou
(integer) 3127.0.0.1:6379> SCARD zs
(integer) 3127.0.0.1:6379> SINTER zs ls
1) "wangwu"127.0.0.1:6379> SDIFF zs ls
1) "zhaoliu"
2) "lisi"127.0.0.1:6379> SUNION zs ls
1) "wangwu"
2) "zhaoliu"
3) "lisi"
4) "mazi"
5) "ergou"127.0.0.1:6379> SISMEMBER zs lisi
(integer) 1127.0.0.1:6379> SISMEMBER ls zhangsan
(integer) 0127.0.0.1:6379> SREM zs lisi
(integer) 1127.0.0.1:6379> SMEMBERS zs
1) "zhaoliu"
2) "wangwu"
SortedSet類型
Redis中的SortedSet是一個可排序的set集合,與Java中的TreeSet有些類似,但底層數(shù)據(jù)結(jié)構(gòu)卻差別很大
SortedSet中的每一個元素都帶有一個score屬性,可以基于score屬性對元素排序,底層的實現(xiàn)是一個跳表(SkipList)加hash表
特性:
-
可排序
-
元素不重復(fù)
-
查詢速度快
因其可排序特性,常被用來實現(xiàn)排行榜這樣的功能
SortedSet的常見命令有:
-
ZADD key score member:添加一個或多個元素到sorted set ,如果已經(jīng)存在則更新其score值
-
ZREM key member:刪除sorted set中的一個指定元素
-
ZSCORE key member : 獲取sorted set中的指定元素的score值
-
ZRANK key member:獲取sorted set 中的指定元素的排名(從0開始)
-
ZCARD key:獲取sorted set中的元素個數(shù)
-
ZCOUNT key min max:統(tǒng)計score值在給定范圍內(nèi)的所有元素的個數(shù)
-
ZINCRBY key increment member:讓sorted set中的指定元素自增,步長為指定的increment值
-
ZRANGE key min max:按照score排序后,獲取指定排名范圍內(nèi)的元素
-
ZRANGEBYSCORE key min max:按照score排序后,獲取指定score范圍內(nèi)的元素
-
ZDIFF.ZINTER.ZUNION:求差集、交集、并集
注意:所有的排名默認(rèn)都是升序,如果要降序則在命令的Z后加REV即可,例如:
-
升序獲取sorted set 中的指定元素的排名:ZRANK key member
-
降序獲取sorted set 中的指定元素的排名:ZREVRANK key memeber
案例: