Redis笔记6:数据类型之哈希(Hash)

命令                  描述                                  语法
HSET            给key中filed字段赋值                  HSET key field value
HGET            获取key中filed的值                    HGET key field
HMSET           设置多个filed字段value                HMSET key field value [field value ...]
HMGET           获取所有filed字段的值                  HMGET key field [field ...]
HSETNX          如果filed不存赋值否则不做操作           HSETNX key field value
HEXISTS         判断filed是否存在 01                HEXISTS key field
HLEN            获取key 的长度                         HLEN key
HDEL            删除file字段                           HDEL key field [field ...]       
HINCRBY         给filed增加步长                        HINCRBY key field increment
HGETALL         获取所有的filed和value                 HGETALL key
HKEYS           获取key                               HKEYS key
HVALS           获取value                             HVALS key

1、HSET key field value

将哈希表 key 中的域 field 的值设为 value 。 如果 key 不存在,一个新的哈希表被创建并进行HSET 操作。 如果域 field 已经存在于哈希表中,旧值将被覆盖。
返回值: 如果 field 是哈希表中的一个新建域,并且值设置成功,返回 1 。 如果哈希表中域 field 已经存在且旧值已被新值覆盖,返回 0 。
示例:

127.0.0.1:6379[15]> HSET website google "www.g.cn"
(integer) 1
127.0.0.1:6379[15]> HSET website google "www.google.com"
(integer) 0
127.0.0.1:6379> HGET website google
"www.google.com"

2、HGET key field

返回哈希表 key 中给定域 field 的值。
返回值: 给定域的值。 当给定域不存在或是给定 key 不存在时,返回 nil 。
示例:

127.0.0.1:6379[15]> HSET site redis redis.com
(integer) 1
127.0.0.1:6379[15]> HGET site redis
"redis.com"
127.0.0.1:6379[15]> HGET site mysql
(nil)

3、HMSET key field value [field value …]

同时将多个 field-value (域 -值) 对设置到哈希表 key 中。此命令会覆盖哈希表中已存在的域。 如果 key 不存在,一个空哈希表被创建并执行HMSET 操作。
返回值: 如果命令执行成功,返回 OK 。 当 key 不是哈希表 (hash) 类型时,返回一个错误。
示例:

127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
OK
127.0.0.1:6379[15]> HGET website google
"www.google.com"
127.0.0.1:6379[15]> HGET website yahoo
"www.yahoo.com"

4、HMGET key field1…fieldN

返回哈希表 key 中,一个或多个给定域的值。 如果给定的域不存在于哈希表,那么返回一个 nil 值。 因为不存在的 key 被当作一个空哈希表来处理,所以对一个不存在的 key 进行HMGET 操作将返回一个只 带有 nil 值的表。
返回值: 一个包含多个给定域的关联值的表,表值的排列顺序和给定域参数的请求顺序一样。
示例:

127.0.0.1:6379[15]>  HMSET pet dog "doudou" cat "nounou"
OK
127.0.0.1:6379[15]>  HMGET pet dog cat fake_pet
1) "doudou"
2) "nounou"
3) (nil)

5、HSETNX key field value

将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在。若域 field 已经存在,该操作无效。 如果 key 不存在,一个新哈希表被创建并执行HSETNX 命令。
返回值: 设置成功,返回 1 。 如果给定域已经存在且没有操作被执行,返回 0 。
示例:

127.0.0.1:6379[15]> HSETNX nosql key-value-store redis
(integer) 1
127.0.0.1:6379[15]>  HSETNX nosql key-value-store Memcached
(integer) 0
127.0.0.1:6379[15]> HGET nosql key-value-store
"redis"

6、HEXISTS key field

查看哈希表 key 中,给定域 field 是否存在。
返回值: 如果哈希表含有给定域,返回 1 。 如果哈希表不含有给定域,或 key 不存在,返回 0 。
示例:

127.0.0.1:6379[15]> HEXISTS phone myphone
(integer) 0
127.0.0.1:6379[15]> HSET phone myphone iphone6
(integer) 1
127.0.0.1:6379[15]> HEXISTS phone myphone
(integer) 1

7、HLEN key

返回哈希表 key 中域的数量。
返回值: 哈希表中域的数量。 当 key 不存在时,返回 0 。
**示例:

127.0.0.1:6379[15]> HSET db redis redis.com
(integer) 1
127.0.0.1:6379[15]> HSET db mysql mysql.com
(integer) 1
127.0.0.1:6379[15]> HLEN db
(integer) 2
127.0.0.1:6379[15]> HSET db mongodb mongodb.org
(integer) 1
127.0.0.1:6379[15]> HLEN db
(integer) 3

8、HDEL key field [field …]

删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。
返回值: 被成功移除的域的数量,不包括被忽略的域。
示例:

127.0.0.1:6379[15]> HMSET key f1 "v1" f2 "v2" f3 "v3" f4 "v4"
OK
127.0.0.1:6379[15]> HGETALL key
1) "f1"
2) "v1"
3) "f2"
4) "v2"
5) "f3"
6) "v3"
7) "f4"
8) "v4"
127.0.0.1:6379[15]> HDEL key f1
(integer) 1
127.0.0.1:6379[15]> HDEL key not-field
(integer) 0
127.0.0.1:6379[15]> HDEL key f2 f3
(integer) 2
127.0.0.1:6379[15]> HDEL key f4 f1
(integer) 1

9、HINCRBY key field increment

为哈希表 key 中的域 field 的值加上增量 increment 。 增量也可以为负数,相当于对给定域进行减法操作。 如果 key 不存在,一个新的哈希表被创建并执行HINCRBY 命令。 如果域 field 不存在,那么在执行命令前,域的值被初始化为 0 。 对一个储存字符串值的域 field 执行HINCRBY 命令将造成一个错误。 本操作的值被限制在 64 位 (bit) 有符号数字表示之内。
返回值: 执行HINCRBY 命令之后,哈希表 key 中域 field 的值。
示例:

127.0.0.1:6379[15]> HEXISTS counter page_view
(integer) 0
127.0.0.1:6379[15]>  HINCRBY counter page_view 200
(integer) 200
127.0.0.1:6379[15]> HGET counter page_view
"200"
127.0.0.1:6379[15]>  HINCRBY counter page_view -50
(integer) 150
127.0.0.1:6379[15]>  HGET counter page_view
"150"

10、HGETALL key

返回哈希表 key 中,所有的域和值。 在返回值里,紧跟每个域名 (field name) 之后是域的值 (value),所以返回值的长度是哈希表大小的两倍。
返回值: 以列表形式返回哈希表的域和域的值。 若 key 不存在,返回空列表。
示例:

127.0.0.1:6379[15]> HSET people jack "Jack Sparrow"
(integer) 1
127.0.0.1:6379[15]> HSET people gump "Forrest Gump"
(integer) 1
127.0.0.1:6379[15]> HGETALL people
1) "jack"
2) "Jack Sparrow"
3) "gump"
4) "Forrest Gump"

11、HKEYS key

返回哈希表 key 中的所有域。
返回值: 一个包含哈希表中所有域的表。 当 key 不存在时,返回一个空表。
示例:

127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
OK
127.0.0.1:6379[15]> HKEYS website
1) "google"
2) "yahoo"
127.0.0.1:6379[15]> EXISTS fake_key
(integer) 0
127.0.0.1:6379[15]> HKEYS fake_key
(empty list or set)

12、HVALS key

返回哈希表 key 中所有域的值。
返回值: 一个包含哈希表中所有值的表。 当 key 不存在时,返回一个空表。
示例:

127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
OK
127.0.0.1:6379[15]> HVALS website
1) "www.google.com"
2) "www.yahoo.com"
127.0.0.1:6379[15]> EXISTS not_exists
(integer) 0
127.0.0.1:6379[15]> HVALS not_exists
(empty list or set)

(完毕)

参考:http://blog.csdn.net/thinkercode/article/details/46552895

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis异常JedisConnectionException:Read timed out通常是由于Redis连接超时引起的,解决方法如下: 1. 增加超时时间 在Jedis连接Redis时,可以通过设置timeout参数来增加连接超时时间。例如: ```java Jedis jedis = new Jedis("localhost", 6379, 5000); ``` 上述代码中,timeout参数为5000,表示连接超时时间为5秒。可以根据实际情况适当增加超时时间。 2. 检查Redis服务是否正常运行 如果Redis服务停止或异常,会导致连接超时。可以通过以下命令检查Redis服务是否正常运行: ```sh redis-cli ping ``` 如果返回PONG,则表示Redis服务正常运行;否则可能需要重启Redis服务。 3. 检查网络连接 如果网络连接不稳定或存在问题,会导致连接超时。可以通过以下命令检查网络连接是否正常: ```sh ping IP地址 ``` 如果网络连接正常,则可以排除网络问题。如果网络连接存在问题,则需要解决网络问题。 4. 增加Redis最大连接数 如果Redis并发连接数较多,可能会导致连接超时。可以通过以下命令增加Redis最大连接数: ```sh config set maxclients 10000 ``` 上述命令将Redis最大连接数设置为10000,可以根据实际情况适当增加最大连接数。 总之,JedisConnectionException:Read timed out异常通常是由于连接超时引起的,可以通过增加超时时间、检查Redis服务是否正常运行、检查网络连接、增加Redis最大连接数等方法来解决。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值