redis中的Hash数据类型

牛逼的人在干牛逼的事之前总有一段苦逼的岁月,只要像傻逼一样坚持,终究也会牛逼


HSET key field value

将哈希表 key 中的域 field 的值设为 value 。

如果 key 不存在,一个新的哈希表被创建并进行 HSET 操作。

如果域 field 已经存在于哈希表中,旧值将被覆盖。

127.0.0.1:6379[1]> hset hh k1 hash      
(integer) 1
127.0.0.1:6379[1]> hget hh k1
"hash"

HDEL key field [field ...]

删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。

127.0.0.1:6379[1]> hset hh k1 hash
(integer) 1
127.0.0.1:6379[1]> hget hh k1
"hash"
127.0.0.1:6379[1]> hdel hh k1
(integer) 1
127.0.0.1:6379[1]> hget hh k1
(nil)

HEXISTS key field

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

127.0.0.1:6379[1]> hset hh k1 hash
(integer) 1
127.0.0.1:6379[1]> hset hh k2 hash2
(integer) 1
127.0.0.1:6379[1]> hset hh k3 hash3
(integer) 1
127.0.0.1:6379[1]> hset hh k4 hash4
(integer) 1
127.0.0.1:6379[1]> hset hh k5 hash5
(integer) 1

127.0.0.1:6379[1]> hexists hh k5        k5存在
(integer) 1

HGETALL key

返回哈希表 key 中,所有的域和值。

在返回值里,紧跟每个域名(field name)之后是域的值(value),所以返回值的长度是哈希表大小的两倍。

127.0.0.1:6379[1]> hgetall hh
 1) "k1"
 2) "hash"
 3) "k2"
 4) "hash2"
 5) "k3"
 6) "hash3"
 7) "k4"
 8) "hash4"
 9) "k5"
10) "hash5"


HINCRBY key field increment

为哈希表 key 中的域 field 的值加上增量 increment 。

增量也可以为负数,相当于对给定域进行减法操作。

如果 key 不存在,一个新的哈希表被创建并执行 HINCRBY 命令。

如果域 field 不存在,那么在执行命令前,域的值被初始化为 0 。

对一个储存字符串值的域 field 执行 HINCRBY 命令将造成一个错误。

127.0.0.1:6379[1]> hset hh k6 666
(integer) 1
127.0.0.1:6379[1]> hincrby hh k6 111
(integer) 777


HINCRBYFLOAT key field increment

为哈希表 key 中的域 field 加上浮点数增量 increment 。

如果哈希表中没有域 field ,那么 HINCRBYFLOAT 会先将域 field 的值设为 0 ,然后再执行加法操作。

如果键 key 不存在,那么 HINCRBYFLOAT 会先创建一个哈希表,再创建域 field ,最后再执行加法操作。

当以下任意一个条件发生时,返回一个错误:

  • 域 field 的值不是字符串类型(因为 redis 中的数字和浮点数都以字符串的形式保存,所以它们都属于字符串类型)
  • 域 field 当前的值或给定的增量 increment 不能解释(parse)为双精度浮点数(double precision floating point number)
127.0.0.1:6379[1]> hincrby hh k6 111              field为k6加上111
(integer) 777

127.0.0.1:6379[1]> hincrbyfloat hh k6 0.99       field为k6加上0.99
"777.98999999999999999"


HKEYS key

返回哈希表 key 中的所有域(field)。

127.0.0.1:6379[1]> hkeys hh
1) "k1"
2) "k2"
3) "k3"
4) "k4"
5) "k5"
6) "k6"


HLEN key

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

127.0.0.1:6379[1]> hlen hh
(integer) 6               6个


HMGET key field [field ...]

返回哈希表 key 中,一个或多个给定域的值。

如果给定的域不存在于哈希表,那么返回一个 nil 值。

因为不存在的 key 被当作一个空哈希表来处理,所以对一个不存在的 key 进行 HMGET 操作将返回一个只带有 nil 值的表。

127.0.0.1:6379[1]> hmget hh k1 k2 k3 k4
1) "hash"
2) "hash2"
3) "hash3"
4) "hash4"


HMSET key field value [field value ...]

同时将多个 field-value (域-值)对设置到哈希表 key 中。

此命令会覆盖哈希表中已存在的域。

如果 key 不存在,一个空哈希表被创建并执行 HMSET 操作。

127.0.0.1:6379[1]> hmset hh k7 hash7 k8 hash8
OK
127.0.0.1:6379[1]> hgetall hh
 1) "k1"
 2) "hash"
 3) "k2"
 4) "hash2"
 5) "k3"
 6) "hash3"
 7) "k4"
 8) "hash4"
 9) "k5"
10) "hash5"
11) "k6"
12) "777.98999999999999999"
13) "k7"
14) "hash7"
15) "k8"
16) "hash8"


HSETNX key field value

将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在。   

若域 field 已经存在,该操作无效。

如果 key 不存在,一个新哈希表被创建并执行 HSETNX 命令。

127.0.0.1:6379[1]> hsetnx hh k9 hash9                            k9不存在,可以设置
(integer) 1
127.0.0.1:6379[1]> hgetall hh
 1) "k1"
 2) "hash"
 3) "k2"
 4) "hash2"
 5) "k3"
 6) "hash3"
 7) "k4"
 8) "hash4"
 9) "k5"
10) "hash5"
11) "k6"
12) "777.98999999999999999"
13) "k7"
14) "hash7"
15) "k8"
16) "hash8"
17) "k9"
18) "hash9"


HVALS key

返回哈希表 key 中所有域的值。

127.0.0.1:6379[1]> hvals hh
1) "hash"
2) "hash2"
3) "hash3"
4) "hash4"
5) "hash5"
6) "777.98999999999999999"
7) "hash7"
8) "hash8"


HSTRLEN key field

返回哈希表 key 中, 与给定域 field 相关联的值的字符串长度(string length)。

如果给定的键或者域不存在, 那么命令返回 0 。

9) "hash9"
127.0.0.1:6379[1]> hstrlen hh k9
(integer) 5                    


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值