婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Redis教程(四):Hashes數據類型

Redis教程(四):Hashes數據類型

熱門標簽:杭州400電話如何申請的 400電話申請怎么看 隨州營銷電話機器人怎么樣 天音通信電話機器人 機器人電話機創意繪畫 高德地圖標注商家在哪 400電話從哪里申請濱州 hbuilder地圖標注 江西南昌百應電話機器人

一、概述:

      我們可以將Redis中的Hashes類型看成具有String Key和String Value的map容器。所以該類型非常適合于存儲值對象的信息。如Username、Password和Age等。如果Hash中包含很少的字段,那么該類型的數據也將僅占用很少的磁盤空間。每一個Hash可以存儲4294967295個鍵值對。

二、相關命令列表:

命令原型 時間復雜度 命令描述 返回值
HSET key field value O(1) 為指定的Key設定Field/Value對,如果Key不存在,該命令將創建新Key以參數中的Field/Value對,如果參數中的Field在該Key中已經存在,則用新值覆蓋其原有值。  1表示新的Field被設置了新值,0表示Field已經存在,用新值覆蓋原有值。 
HGET key field  O(1)  返回指定Key中指定Field的關聯值。 返回參數中Field的關聯值,如果參數中的Key或Field不存,返回nil。
HEXISTSkey field  O(1)  判斷指定Key中的指定Field是否存在。 1表示存在,0表示參數中的Field或Key不存在。
HLEN key  O(1) 獲取該Key所包含的Field的數量。 返回Key包含的Field數量,如果Key不存在,返回0。
HDEL key field [field ...]  O(N) 時間復雜度中的N表示參數中待刪除的字段數量。從指定Key的Hashes Value中刪除參數中指定的多個字段,如果不存在的字段將被忽略。如果Key不存在,則將其視為空Hashes,并返回0. 實際刪除的Field數量。
HSETNXkey field value O(1) 只有當參數中的Key或Field不存在的情況下,為指定的Key設定Field/Value對,否則該命令不會進行任何操作。  1表示新的Field被設置了新值,0表示Key或Field已經存在,該命令沒有進行任何操作。
HINCRBYkey field increment  O(1) 增加指定Key中指定Field關聯的Value的值。如果Key或Field不存在,該命令將會創建一個新Key或新Field,并將其關聯的Value初始化為0,之后再指定數字增加的操作。該命令支持的數字是64位有符號整型,即increment可以負數。  返回運算后的值。
HGETALLkey O(N)  時間復雜度中的N表示Key包含的Field數量。獲取該鍵包含的所有Field/Value。其返回格式為一個Field、一個Value,并以此類推。 Field/Value的列表。
HKEYSkey  O(N) 時間復雜度中的N表示Key包含的Field數量。返回指定Key的所有Fields名。 Field的列表。
HVALSkey  O(N) 時間復雜度中的N表示Key包含的Field數量。返回指定Key的所有Values名。  Value的列表。 
HMGETkey field [field ...]  O(N)  時間復雜度中的N表示請求的Field數量。獲取和參數中指定Fields關聯的一組Values。如果請求的Field不存在,其值返回nil。如果Key不存在,該命令將其視為空Hash,因此返回一組nil。 返回和請求Fields關聯的一組Values,其返回順序等同于Fields的請求順序。
HMSET key field value [field value ...] O(N) 時間復雜度中的N表示被設置的Field數量。逐對依次設置參數中給出的Field/Value對。如果其中某個Field已經存在,則用新值覆蓋原有值。如果Key不存在,則創建新Key,同時設定參數中的Field/Value。    

三、命令示例:

    1. HSET/HGET/HDEL/HEXISTS/HLEN/HSETNX:
 

復制代碼 代碼如下:

    #在Shell命令行啟動Redis客戶端程序
    /> redis-cli
    #給鍵值為myhash的鍵設置字段為field1,值為stephen。
    redis 127.0.0.1:6379> hset myhash field1 "stephen"
    (integer) 1
    #獲取鍵值為myhash,字段為field1的值。
    redis 127.0.0.1:6379> hget myhash field1
    "stephen"
    #myhash鍵中不存在field2字段,因此返回nil。
    redis 127.0.0.1:6379> hget myhash field2
    (nil)
    #給myhash關聯的Hashes值添加一個新的字段field2,其值為liu。
    redis 127.0.0.1:6379> hset myhash field2 "liu"
    (integer) 1
    #獲取myhash鍵的字段數量。
    redis 127.0.0.1:6379> hlen myhash
    (integer) 2
    #判斷myhash鍵中是否存在字段名為field1的字段,由于存在,返回值為1。
    redis 127.0.0.1:6379> hexists myhash field1
    (integer) 1
    #刪除myhash鍵中字段名為field1的字段,刪除成功返回1。
    redis 127.0.0.1:6379> hdel myhash field1
    (integer) 1
    #再次刪除myhash鍵中字段名為field1的字段,由于上一條命令已經將其刪除,因為沒有刪除,返回0。
    redis 127.0.0.1:6379> hdel myhash field1
    (integer) 0
    #判斷myhash鍵中是否存在field1字段,由于上一條命令已經將其刪除,因為返回0。
    redis 127.0.0.1:6379> hexists myhash field1
    (integer) 0
    #通過hsetnx命令給myhash添加新字段field1,其值為stephen,因為該字段已經被刪除,所以該命令添加成功并返回1。
    redis 127.0.0.1:6379> hsetnx myhash field1 stephen
    (integer) 1
    #由于myhash的field1字段已經通過上一條命令添加成功,因為本條命令不做任何操作后返回0。
    redis 127.0.0.1:6379> hsetnx myhash field1 stephen
    (integer) 0

   2. HINCRBY:
  
復制代碼 代碼如下:

    #刪除該鍵,便于后面示例的測試。
    redis 127.0.0.1:6379> del myhash
    (integer) 1
    #準備測試數據,該myhash的field字段設定值1。
    redis 127.0.0.1:6379> hset myhash field 5
    (integer) 1
    #給myhash的field字段的值加1,返回加后的結果。
    redis 127.0.0.1:6379> hincrby myhash field 1
    (integer) 6
    #給myhash的field字段的值加-1,返回加后的結果。
    redis 127.0.0.1:6379> hincrby myhash field -1
    (integer) 5
    #給myhash的field字段的值加-10,返回加后的結果。
    redis 127.0.0.1:6379> hincrby myhash field -10
    (integer) -5  

    3. HGETALL/HKEYS/HVALS/HMGET/HMSET:
 
復制代碼 代碼如下:

    #刪除該鍵,便于后面示例測試。
    redis 127.0.0.1:6379> del myhash
    (integer) 1
    #為該鍵myhash,一次性設置多個字段,分別是field1 = "hello", field2 = "world"。
    redis 127.0.0.1:6379> hmset myhash field1 "hello" field2 "world"
    OK
    #獲取myhash鍵的多個字段,其中field3并不存在,因為在返回結果中與該字段對應的值為nil。
    redis 127.0.0.1:6379> hmget myhash field1 field2 field3
    1) "hello"
    2) "world"
    3) (nil)
    #返回myhash鍵的所有字段及其值,從結果中可以看出,他們是逐對列出的。
    redis 127.0.0.1:6379> hgetall myhash
    1) "field1"
    2) "hello"
    3) "field2"
    4) "world"
    #僅獲取myhash鍵中所有字段的名字。
    redis 127.0.0.1:6379> hkeys myhash
    1) "field1"
    2) "field2"
    #僅獲取myhash鍵中所有字段的值。
    redis 127.0.0.1:6379> hvals myhash
    1) "hello"
    2) "world"

您可能感興趣的文章:
  • redis中hash表內容刪除的方法代碼
  • Python操作redis實例小結【String、Hash、List、Set等】
  • Redis String 類型和 Hash 類型學習筆記與總結
  • SpringBoot+Redis實現數據字典的方法
  • python redis存入字典序列化存儲教程
  • redis中Hash字典操作的方法
  • Redis字典實現、Hash鍵沖突及漸進式rehash詳解

標簽:常德 鶴崗 保定 沈陽 石嘴山 葫蘆島 招商 昆明

巨人網絡通訊聲明:本文標題《Redis教程(四):Hashes數據類型》,本文關鍵詞  Redis,教程,四,Hashes,數據,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Redis教程(四):Hashes數據類型》相關的同類信息!
  • 本頁收集關于Redis教程(四):Hashes數據類型的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 库伦旗| 通化县| 谢通门县| 高台县| 大田县| 岳阳县| 祁门县| 通榆县| 凉城县| 临朐县| 大冶市| 黑河市| 丰城市| 满城县| 英超| 织金县| 新平| 吴堡县| 万州区| 马尔康县| 沙雅县| 广宁县| 新田县| 轮台县| 洛南县| 祁阳县| 太保市| 轮台县| 儋州市| 汕头市| 尚志市| 师宗县| 巨野县| 通海县| 呼图壁县| 通榆县| 五原县| 盐津县| 张家界市| 枣阳市| 凤台县|