国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Redis > 正文

Redis中散列類型的常用命令小結

2020-10-28 21:38:50
字體:
來源:轉載
供稿:網友

Redis散列類型

Redis是采用字典結構以鍵值對的形式存儲數據的,而散列類型(hash)的鍵值也是一種字典結構,其存儲了字段和字段值的映射,但字段值只能是字符串,不支持其他數據類型,也就是說,散列類型不能嵌套其他的數據類型。一個散列類型鍵可以包含至多2^32-1個字段。

除了散列類型,Redis的其他數據類型同樣不支持數據類型嵌套。比如集合類型的每個元素只能是字符串,不能是一個集合或者散列表等。

散列類型適合存儲對象:使用對象類別和ID構成建名,使用字段表示對象的屬性,而字段值存儲屬性值。例如要存儲ID為2的汽車對象,可以分別使用名為color、name和price的三個字段來存儲該汽車的顏色、名稱和價格。

1、基本命令

例如現在要存儲ID為1的文章,分別有title、author、time、content

則鍵為post:1,字段分別為title、author、time、content,值分別為“the first post”、“me”、“2014-03-04”、“This is my first post.”,存儲如下

redis 127.0.0.1:6379> hmset post:1 title "the first post" author "JoJo" time 2016/08/25 content "this is my first post"OK

這里使用的是hmset命令,具體散列的基本賦值命令如下:

hset key field value   #例如hset post:2 title “second post”

hget key field             #例如hget post:2 title,獲取id為2的post的title值

hmset key field value [field value ...]  #這個同上,批量存值

hmget key field [field ...]                      #批量取值,取得列表

例:

redis 127.0.0.1:6379> hmget post:1 time author1) "2016/08/25"2) "JoJo"

hgetall key                  #取得key所對應的所有鍵值列表,這里給出個例子

redis 127.0.0.1:6379> hgetall post:11) "title"2) "the first post"3) "author"4) "JoJo"5) "time"6) "2016/08/25"7) "content"8) "this is my first post"

 2、判斷是否存在

hexists key field

如果存在返回1,否則返回0(如果鍵不存在也返回0)。

3、當字段不存在時賦值

hsetnx key field value

這個和hset的區別就是如果字段存在,這個命令將不執行任何操作,但是這里有一個區別就是Redis提供的這些命令都是原子操作,不會產生數據不一致問題。

例:

redis 127.0.0.1:6379> hexists post:1 time(integer) 1  //判斷是存在time字段的redis 127.0.0.1:6379> hsetnx post:1 time 2016/08/26(integer) 0  //不存在的話,設置time,存在的話返回0,值不變,原始值redis 127.0.0.1:6379> hget post:1 time"2016/08/25"redis 127.0.0.1:6379> hsetnx post:1 age 23(integer) 1   //不存在age字段,返回1,并設置age字段redis 127.0.0.1:6379> hget post:1 age"23"

4、增加數字

hincrby key field number

這里就和incry命令類似了。

例:

redis 127.0.0.1:6379> hincrby post:1 age 2(integer) 25

5、刪除字段

hdel key field [field ...]

刪除字段,一個或多個,返回值是被刪除字段的個數。

6、其他命令

hkeys key    #獲取字段名

hvals key    #獲取字段名

示例如下:

redis 127.0.0.1:6379> hkeys post:11) "title"2) "author"3) "time"4) "content"5) "age"redis 127.0.0.1:6379> hvals post:11) "the first post"2) "JoJo"3) "2016/08/25"4) "this is my first post"5) "25"

最后還有一個就是獲取字段數量的命令:

hlen key

返回字段的數量

redis 127.0.0.1:6379> hlen post:1(integer) 5

總結

以上就是Redis中散列類型常用命令的全部內容了,希望能對大家的學習或者工作帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌宁县| 仁布县| 靖远县| 潼关县| 连云港市| 普格县| 壤塘县| 眉山市| 怀柔区| 昂仁县| 读书| 保靖县| 铜陵市| 肇庆市| 偃师市| 株洲县| 南康市| 宜黄县| 崇仁县| 大石桥市| 虎林市| 南投市| 施甸县| 大安市| 瑞金市| 田阳县| 即墨市| 咸丰县| 沐川县| 沙湾县| 隆回县| 迭部县| 平安县| 台东市| 天祝| 开远市| 南澳县| 商南县| 邵阳县| 静乐县| 安陆市|