Redis Hash

Hash(哈希表)索引

域-值對,key不會重複,其實哈希表就像是一個只有String類型的Redis。rem

 

一、基本操做(CURD)字符串

>hmset key field value [field value ...]get

將多個 field-value (域-值)對設置到哈希表 key 中,新的域-值對會覆蓋哈希表中已存在的域-值對。string

 

>hset key field value擴展

將單個 field-value (域-值)對設置到哈希表 key 中,新的域-值對會覆蓋哈希表中已存在的域-值對。遍歷

 

>hsetnx key field valuefloat

將哈希表 key 中的域 field 的值設置爲 value ,當且僅當域 field 不存在。若域 field 已經存在,該操做無效。數據

 

>hmget key field [field ...]di

返回哈希表 key 中,一個或多個給定域的值。若是key不存在則返回null.

 

>hget key field

返回哈希表 key 中,一個給定域的值。若是key不存在則返回null.

 

>hdel key field [field ...]

原子操做,刪除哈希表 key 中的一個或多個指定域,不存在的域將被忽略。

 

二、擴展操做

>hgetall key

返回哈希表 key 中全部的域-值對,以列表形式返回,奇數索引下的值爲域,偶數索引下的值爲域對應的值,數據量大時儘可能不用。

 

>hkeys key

返回哈希表 key 中的全部域,數據量大時儘可能不用。

 

>hvals key

返回哈希表 key 中的全部域對應的值,數據量大時儘可能不用。

 

>hexists key field

查看哈希表 key 中,給定域 field 是否存在。

 

>hlen key

返回哈希表 key 中域的數量。

 

>hstrlen key field

返回哈希表 key 中, 與給定域 field 相關聯的值的字符串長度(string length)。

 

>hscan key cursor [MATCH pattern] [COUNT count]

經過遊標遍歷哈希表,每次批量返回必定數量的數據,他比 hkeys hvals hgetall 都要好,緣由是數據量大時,他們都會被阻塞。

 

三、修改操做 i++

>hincrby key field increment

爲哈希表 key 中的域 field 的值加上增量 increment 。增量也能夠爲負數,至關於對給定域進行減法操做。若是不存在默認初始化爲0而後進行對應的加減操做。

 

>hincrbyfloat key field increment

爲哈希表 key 中的域 field 加上浮點數增量 increment,增量也能夠爲負數,至關於對給定域進行減法操做 。若是哈希表中沒有域 field ,那麼 hincrbyfloat 會先將域 field 的值設爲 0 ,而後再執行加法操做。

相關文章
相關標籤/搜索