您好,登錄后才能下訂單哦!
| 一個散列由多個域 值對(field-value pair)組成,散列的域和值都可以 是文字,整數(shù),浮點數(shù)或者二進(jìn)制數(shù)據(jù)。 # 同一個散列中每個域必須是獨(dú)一無二的,而不同域的值可以是重復(fù)的。 # 操作:設(shè)置域值對,獲取域的值,檢查域是否存在 | 基本操作 -- 關(guān)聯(lián)域值對 hset key field value # 在散列鍵key中關(guān)聯(lián)給定的域值對field和value # 如果域field之前沒有關(guān)聯(lián)值,那么命令返回1; # 如果域field已經(jīng)有關(guān)聯(lián)值,那么命令用新值覆蓋舊值,并返回0。 -- 獲取域關(guān)聯(lián)的值 hget key field # 返回散列鍵key中,域field鎖關(guān)聯(lián)的值。如果域field沒有關(guān)聯(lián)值, 那么返回nil -- 僅當(dāng)域不存在時,關(guān)聯(lián)域值對 hsetnx key field value # 如果散列鍵key中,域field不存在,那么關(guān)聯(lián)給定的域值對field和value # 如果域field已經(jīng)有與之相關(guān)聯(lián)的值,那么命令不做動作 redis> hsetnx message 'content' 'good morning,jack!' (integer) 1 redis>hsetnx message 'content' 'good morning, jack!' # 不做動作,不做修改 (integer) 0 -- 檢查域是否存在 hexists key field # 查看散列鍵key中,給定域field是否存在:存在返回1,不存在返回0 -- 刪除給定域值對 hdel key field [field ...] # 刪除散列鍵key中的一個或多個指定域,以及那些域的值; # 不存在的域?qū)⒈缓雎?,命令返回被成功刪除的域值對數(shù)量。 -- 獲取散列包含的鍵值對數(shù)量 hlen key # 返回散列鍵key包含的域值對數(shù)量 redis> hlen message (integer) 4 | 批量操作 -- 一次設(shè)置或獲取散列中的多個域值對 hmset key field value [field value ...] # 在散列鍵key中關(guān)聯(lián)多個與之對 hmget key field [field ...] # 返回散列鍵key中,一個或多個域的值 -- 獲取散列包含的所有域、值、或者域值對 hkeys key 返回散列鍵key包含的所有域 hvals key 返回散列鍵key中所有域的值 hgetall key 返回散列鍵key包含的所有域值對 # 為什么命令叫hkeys而不是hfields? 對于散列來說,key和field表示的是同一個意思,并且key比field更容易拼寫, 所以Redis選擇使用hkeys來做命令的名字,而不是hfields。 | 數(shù)字操作 --對域的值執(zhí)行自增操作 hincrby key field increment # 在域field的值家伙是哪個整數(shù)增量increment hincrbyfloat key field increment #9 在域field的值加上浮點數(shù)增量increment # 雖然Redis沒有提供對應(yīng)的hdecrby和hdecrbyfloat命令,我們同樣可以 # 通過將increment設(shè)為負(fù)數(shù)來達(dá)到做減法的效果 redis> hincrby numbers x 100 # 域不存在,先將值初始化為0, (integer) 100 然后再執(zhí)行hincrby操作 redis> hincrby numbers x -50 # 傳入負(fù)值,做減法 (integer) 50 redis> hincrbyfloat numbers x 3.14 # 浮點數(shù)計算 '53.14'
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。