Redis中的Hash和List類型常用命令及應(yīng)用分析
Redis內(nèi)存數(shù)據(jù)庫中,除了基礎(chǔ)的String類型外,Hash和List也是開發(fā)中頻繁使用的兩種數(shù)據(jù)結(jié)構(gòu),下面詳細講解Hash和List類型的特點、常用命令及典型應(yīng)用場景,以便處理復(fù)雜業(yè)務(wù)需求。
一、Hash類型詳解
Hash類型(哈希)是一個鍵值對集合,類似于Java中的HashMap
或Python中的字典。它適合存儲對象類數(shù)據(jù),能夠?qū)崿F(xiàn)對對象屬性的精準(zhǔn)操作,避免了String類型中序列化整個對象的開銷。
1. Hash類型的特點
- 鍵值結(jié)構(gòu):每個Hash類型的鍵(key)下包含多個字段(field)和對應(yīng)的值(value)
- 二進制安全:field和value都支持二進制數(shù)據(jù)
- 內(nèi)存高效:存儲對象數(shù)據(jù)比String類型更節(jié)省空間
- 操作靈活:可單獨對某個字段進行CRUD,無需操作整個對象
2. 常用命令及示例
假設(shè)我們要存儲用戶信息,以user:100
作為Hash的鍵,包含id
、name
、age
、email
等字段。
(1)設(shè)置字段值
HSET key field value:為哈希表中的字段設(shè)置值,返回受影響的字段數(shù)量
127.0.0.1:6379> HSET user:100 id 100 name "張三" age 25 (integer) 3
HMSET key field1 value1 field2 value2 …:同時設(shè)置多個字段值(Redis 4.0.0后推薦使用HSET替代)
127.0.0.1:6379> HMSET user:100 email "zhangsan@example.com" gender "男" OK
(2)獲取字段值
HGET key field:獲取哈希表中指定字段的值
127.0.0.1:6379> HGET user:100 name "張三"
HMGET key field1 field2 …:獲取多個字段的值
127.0.0.1:6379> HMGET user:100 id age gender 1) "100" 2) "25" 3) "男"
HGETALL key:獲取哈希表中所有字段和值
127.0.0.1:6379> HGETALL user:100 1) "id" 2) "100" 3) "name" 4) "張三" 5) "age" 6) "25" ...
(3)刪除字段
- HDEL key field1 field2 …:刪除哈希表中的一個或多個字段,返回刪除的字段數(shù)量
127.0.0.1:6379> HDEL user:100 gender (integer) 1
(4)其他常用命令
HEXISTS key field:判斷字段是否存在,存在返回1,否則返回0
127.0.0.1:6379> HEXISTS user:100 email (integer) 1
HLEN key:獲取哈希表中字段的數(shù)量
127.0.0.1:6379> HLEN user:100 (integer) 4
HKEYS key:獲取哈希表中所有字段名
127.0.0.1:6379> HKEYS user:100 1) "id" 2) "name" 3) "age" 4) "email"
HVALS key:獲取哈希表中所有字段值
127.0.0.1:6379> HVALS user:100 1) "100" 2) "張三" 3) "25" 4) "zhangsan@example.com"
HINCRBY key field increment:為數(shù)字類型字段增加指定增量
127.0.0.1:6379> HINCRBY user:100 age 1 (integer) 26
3. 應(yīng)用場景
- 存儲對象數(shù)據(jù):如用戶信息、商品詳情、訂單數(shù)據(jù)等
- 統(tǒng)計數(shù)據(jù):如用戶的關(guān)注數(shù)、粉絲數(shù)、文章閱讀量等
- 配置信息:存儲應(yīng)用的各種配置項,支持單獨更新某個配置
二、List類型詳解
List類型(列表)是一個有序的字符串集合,類似于Java中的LinkedList
,允許元素重復(fù),底層采用雙向鏈表結(jié)構(gòu)實現(xiàn),適合做隊列或棧操作。
1. List類型的特點
- 有序性:元素按照插入順序排序
- 雙向操作:可從頭部和尾部插入/刪除元素
- 靈活的范圍操作:支持獲取指定索引范圍的元素
- 內(nèi)存高效:鏈表結(jié)構(gòu)對元素的增刪操作效率高
2. 常用命令及示例
以存儲文章評論列表為例,使用article:100:comments
作為List的鍵。
(1)添加元素
LPUSH key value1 value2 …:從列表頭部插入一個或多個元素,返回插入后列表的長度
127.0.0.1:6379> LPUSH article:100:comments "這篇文章很有用" "學(xué)習(xí)了" (integer) 2
RPUSH key value1 value2 …:從列表尾部插入一個或多個元素
127.0.0.1:6379> RPUSH article:100:comments "感謝分享" (integer) 3
(2)獲取元素
LPOP key:移除并返回列表的第一個元素
127.0.0.1:6379> LPOP article:100:comments "學(xué)習(xí)了"
RPOP key:移除并返回列表的最后一個元素
127.0.0.1:6379> RPOP article:100:comments "感謝分享"
LRANGE key start stop:獲取列表中指定范圍的元素(0表示第一個元素,-1表示最后一個元素)
127.0.0.1:6379> LPUSH article:100:comments "評論1" "評論2" "評論3" (integer) 4 127.0.0.1:6379> LRANGE article:100:comments 0 -1 1) "評論3" 2) "評論2" 3) "評論1" 4) "這篇文章很有用"
LINDEX key index:獲取列表中指定索引的元素
127.0.0.1:6379> LINDEX article:100:comments 1 "評論2"
(3)列表長度與修剪
LLEN key:獲取列表的長度
127.0.0.1:6379> LLEN article:100:comments (integer) 4
LTRIM key start stop:保留列表中指定范圍的元素,刪除其他元素
127.0.0.1:6379> LTRIM article:100:comments 0 1 OK 127.0.0.1:6379> LRANGE article:100:comments 0 -1 1) "評論3" 2) "評論2"
(4)其他常用命令
LREM key count value:刪除列表中與value相等的元素,count指定刪除數(shù)量(正數(shù)從頭部開始,負數(shù)從尾部開始,0刪除所有)
127.0.0.1:6379> LREM article:100:comments 1 "評論2" (integer) 1
LSET key index value:設(shè)置列表中指定索引的元素值
127.0.0.1:6379> LSET article:100:comments 0 "最新評論" OK
RPOPLPUSH source destination:移除source列表的最后一個元素,并將其添加到destination列表的頭部
127.0.0.1:6379> RPOPLPUSH article:100:comments article:101:comments "這篇文章很有用"
3. 應(yīng)用場景
- 消息隊列:利用LPUSH+RPOP實現(xiàn)簡單的FIFO(先進先出)隊列
- 棧結(jié)構(gòu):使用LPUSH+LPOP或RPUSH+RPOP實現(xiàn)LIFO(后進先出)棧
- 最新列表:如最新文章、最新評論,使用LPUSH添加,LRANGE獲取前N條
- 排行榜:結(jié)合LTRIM可實現(xiàn)固定長度的排行榜
- 任務(wù)隊列:通過RPOPLPUSH實現(xiàn)安全的任務(wù)處理(避免任務(wù)丟失)
總結(jié)
- Hash類型適合存儲對象類數(shù)據(jù),支持對單個字段的精準(zhǔn)操作,是存儲用戶信息、商品詳情等數(shù)據(jù)的理想選擇
- List類型基于有序鏈表實現(xiàn),適合構(gòu)建隊列、棧、最新列表等場景,支持靈活的首尾操作和范圍查詢
到此這篇關(guān)于Redis中的Hash和List類型常用命令及應(yīng)用分析的文章就介紹到這了,更多相關(guān)redis hash和list類型常用命令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
緩存替換策略及應(yīng)用(以Redis、InnoDB為例)
本文以Redis、InnoDB為例給大家講解緩存替換策略及應(yīng)用,本文給大家提到五種置換策略,通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2021-07-07Redis中有序集合的內(nèi)部實現(xiàn)方式的詳細介紹
本文主要介紹了Redis中有序集合的內(nèi)部實現(xiàn)方式的詳細介紹,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03淺析Redis中String數(shù)據(jù)類型及其底層編碼
這篇文章主要介紹?Redis?中?String?數(shù)據(jù)類型及其底層編碼,文中有詳細的代碼示例,對大家的工作及學(xué)習(xí)有一定的幫助,需要的朋友可以參考下2023-05-05Springboot/Springcloud項目集成redis進行存取的過程解析
大家都知道Redis支持五種數(shù)據(jù)類型:string(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合),本文重點給大家介紹Springboot/Springcloud項目集成redis進行存取的過程,需要的朋友參考下吧2021-12-12Redis 如何批量設(shè)置過期時間(PIPLINE的使用)
有時候我們并不希望redis的key一直存在。例如緩存,驗證碼等數(shù)據(jù),我們希望它們能在一定時間內(nèi)自動的被銷毀。本文就詳細的介紹一下Redis 如何批量設(shè)置過期時間,感興趣的可以了解一下2021-11-11