Redis通用命令介紹以及key的層級(jí)結(jié)構(gòu)講解
1 Redis數(shù)據(jù)結(jié)構(gòu)介紹
Redis是一個(gè)key-value的數(shù)據(jù)庫(kù),key一般是String類型,不過(guò)value的類型多種多樣:
value的數(shù)據(jù)類型共有8種,前面5中為基本數(shù)據(jù)類型,后面3種是針對(duì)不同的情況指定的特殊數(shù)據(jù)類型。

命令不要死記,學(xué)會(huì)查詢就好啦
Redis為了方便我們學(xué)習(xí),將操作不同數(shù)據(jù)類型的命令也做了分組,在官網(wǎng)( Commands | Redis)可以查看到不同的命令:(點(diǎn)擊COMMANDS)

當(dāng)然我們也可以通過(guò)Help命令來(lái)幫助我們?nèi)ゲ榭疵?/p>

2 Redis通用命令
通用指令是部分?jǐn)?shù)據(jù)類型的,都可以使用的指令,常見(jiàn)的有:
- KEYS:查看符合模板的所有key
- DEL:刪除一個(gè)指定的key
- EXISTS:判斷key是否存在
- EXPIRE:給一個(gè)key設(shè)置有效期,有效期到期時(shí)該key會(huì)被自動(dòng)刪除
- TTL:查看一個(gè)KEY的剩余有效期
通過(guò)help [command] 可以查看一個(gè)命令的具體用法,例如:

接下來(lái)演示上述常用命令的使用:
溫馨提示:以下的內(nèi)容所有的代碼塊都是從命令行窗口復(fù)制過(guò)來(lái)的,包括命令和結(jié)果哦~
1.KEYS:查看符合模板的所有key
127.0.0.1:6379> keys *
1) "name"
2) "age"
127.0.0.1:6379>
# 查詢以a開(kāi)頭的key
127.0.0.1:6379> keys a*
1) "age"
127.0.0.1:6379>
貼心小提示:在生產(chǎn)環(huán)境下,不推薦使用keys 命令,因?yàn)檫@個(gè)命令在key過(guò)多的情況下,效率不高
2.DEL:刪除一個(gè)指定的key
127.0.0.1:6379> help del
DEL key [key ...]
summary: Delete a key
since: 1.0.0
group: generic
127.0.0.1:6379> del name #刪除單個(gè)
(integer) 1 #成功刪除1個(gè)
127.0.0.1:6379> keys *
1) "age"
127.0.0.1:6379> MSET k1 v1 k2 v2 k3 v3 #批量添加數(shù)據(jù)
OK
127.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個(gè),最終返回
127.0.0.1:6379>
127.0.0.1:6379> keys * #再查詢?nèi)康膋ey
1) "age" #只剩下一個(gè)了
127.0.0.1:6379>
貼心小提示:在拷貝代碼的時(shí)候,只需要拷貝對(duì)應(yīng)的命令哦~
3.EXISTS:判斷key是否存在
127.0.0.1:6379> help EXISTS
EXISTS key [key ...]
summary: Determine if a key exists
since: 1.0.0
group: generic
127.0.0.1:6379> exists age
(integer) 1
127.0.0.1:6379> exists name
(integer) 0
4.EXPIRE:給一個(gè)key設(shè)置有效期,有效期到期時(shí)該key會(huì)被自動(dòng)刪除
5.TTL:查看一個(gè)KEY的剩余的存活時(shí)間
127.0.0.1:6379> expire age 10
(integer) 1
127.0.0.1:6379> ttl age
(integer) 8
127.0.0.1:6379> ttl age
(integer) 6
127.0.0.1:6379> ttl age
(integer) -2
127.0.0.1:6379> ttl age
(integer) -2 #當(dāng)這個(gè)key過(guò)期了,那么此時(shí)查詢出來(lái)就是-2
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> set age 10 #如果沒(méi)有設(shè)置過(guò)期時(shí)間
OK
127.0.0.1:6379> ttl age
(integer) -1 # ttl的返回值就是-1
貼心小提示:
(1)內(nèi)存非常寶貴,對(duì)于一些數(shù)據(jù),我們應(yīng)當(dāng)給他一些過(guò)期時(shí)間,當(dāng)過(guò)期時(shí)間到了之后,他就會(huì)自動(dòng)被刪除~
(2)當(dāng)使用TTL命令時(shí),如果返回 -1 值,不是代表已經(jīng)被銷毀,而是代表永久哦~
3 Redis命令-Key的層級(jí)結(jié)構(gòu)
Redis沒(méi)有類似MySQL中的Table的概念,我們?cè)撊绾螀^(qū)分不同類型的key呢?
例如,需要存儲(chǔ)用戶.商品信息到redis,有一個(gè)用戶id是1,有一個(gè)商品id恰好也是1,此時(shí)如果使用id作為key,那就會(huì)沖突了,該怎么辦?
我們可以通過(guò)給key添加前綴加以區(qū)分,不過(guò)這個(gè)前綴不是隨便加的,有一定的規(guī)范:
Redis的key允許有多個(gè)單詞形成層級(jí)結(jié)構(gòu),多個(gè)單詞之間用':'隔開(kāi),格式如下:

這個(gè)格式并非固定,也可以根據(jù)自己的需求來(lái)刪除或添加詞條。
這個(gè)格式并非固定,也可以根據(jù)自己的需求來(lái)刪除或添加詞條。
例如我們的項(xiàng)目名稱叫 heima,有user和product兩種不同類型的數(shù)據(jù),我們可以這樣定義key:
- user相關(guān)的key:heima:user:1
- product相關(guān)的key:heima:product:1
如果Value是一個(gè)Java對(duì)象,例如一個(gè)User對(duì)象,則可以將對(duì)象序列化為JSON字符串后存儲(chǔ):
| KEY | VALUE |
|---|---|
| heima:user:1 | {"id":1, "name": "Jack", "age": 21} |
| heima:product:1 | {"id":1, "name": "小米11", "price": 4999} |
一旦我們向redis采用這樣的方式存儲(chǔ),那么在可視化界面中,redis會(huì)以層級(jí)結(jié)構(gòu)來(lái)進(jìn)行存儲(chǔ),形成類似于這樣的結(jié)構(gòu),更加方便Redis獲取數(shù)據(jù)

到此這篇關(guān)于Redis通用命令介紹以及key的層級(jí)結(jié)構(gòu)講解的文章就介紹到這了,更多相關(guān)Redis通用命令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Windows系統(tǒng)一鍵啟動(dòng)Redis腳本
本文介紹了在Windows系統(tǒng)中創(chuàng)建一鍵啟動(dòng)Redis的腳本,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-12-12
redis實(shí)現(xiàn)分布式session的解決方案
session存放在服務(wù)器,關(guān)閉瀏覽器不會(huì)失效,本文主要介紹了redis實(shí)現(xiàn)分布式session的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Redis之RedisTemplate配置方式(序列和反序列化)
這篇文章主要介紹了Redis之RedisTemplate配置方式(序列和反序列化),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
如何利用Redis?List實(shí)現(xiàn)Java數(shù)據(jù)庫(kù)分頁(yè)快速查詢
這篇文章主要給大家介紹了關(guān)于如何利用Redis?List實(shí)現(xiàn)Java數(shù)據(jù)庫(kù)分頁(yè)快速查詢的相關(guān)資料,Redis是一個(gè)高效的內(nèi)存數(shù)據(jù)庫(kù),它支持包括String、List、Set、SortedSet和Hash等數(shù)據(jù)類型的存儲(chǔ),需要的朋友可以參考下2024-02-02
windows環(huán)境下Redis+Spring緩存實(shí)例講解
這篇文章主要為大家詳細(xì)介紹了windows環(huán)境下Redis+Spring緩存實(shí)例教程,感興趣的小伙伴們可以參考一下2016-04-04
使用Redis防止重復(fù)發(fā)送RabbitMQ消息的方法詳解
今天遇到一個(gè)問(wèn)題,發(fā)送MQ消息的時(shí)候需要保證不會(huì)重復(fù)發(fā)送,注意不是可靠到達(dá),這里保證的是不會(huì)生產(chǎn)多條一樣的消息,所以本文主要介紹了使用Redis防止重復(fù)發(fā)送RabbitMQ消息的方法,需要的朋友可以參考下2025-01-01

