Redis教程9-哈希(Hash)常用命令使用参考1

网友投稿 588 2022-10-17

Redis教程9-哈希(Hash)常用命令使用参考1

Redis教程9-哈希(Hash)常用命令使用参考1

1.HDEL

HDEL key field [field ...]

删除哈希表 key

在Redis2.4以下的版本里, HDEL 每次只能删除单个域,如果你需要在一个原子时间内删除多个域,请将命令包含在 MULTI / EXEC 块内。

可用版本:>= 2.0.0

时间复杂度:O(N), N

返回值:被成功移除的域的数量,不包括被忽略的域。

127.0.0.1:6379> hmset user name zhangsan age 20 tel 12111112203 address chineseOK127.0.0.1:6379> hgetall user // 所有field和values1) "name"2) "zhangsan"3) "age"4) "20"5) "tel"6) "12111112203"7) "address"8) "chinese"127.0.0.1:6379> hdel user address tel // 删除存在的field域(integer) 2127.0.0.1:6379> hgetall user1) "name"2) "zhangsan"3) "age"4) "20"127.0.0.1:6379> hdel user abcd // 删除单个不存在的field域(integer) 0127.0.0.1:6379> hdel user abcd age // 删除多个field域, adbc不存在, age存在(integer) 1127.0.0.1:6379> hgetall user1) "name"2) "zhangsan"

2.HEXISTS

HEXISTS key field

查看哈希表 key 中,给定域 field

可用版本:>= 2.0.0

时间复杂度:O(1)

返回值:

如果哈希表含有给定域,返回 1

如果哈希表不含有给定域,或 key 不存在,返回 0

127.0.0.1:6379> hgetall user1) "name"2) "zhangsan"127.0.0.1:6379> hexists user name // name存在(integer) 1127.0.0.1:6379> hexists user age // age不存在(integer) 0127.0.0.1:6379> hexists person name // person不存在(integer) 0

3.HGET

HGET key field

返回哈希表 key 中给定域 field

可用版本:>= 2.0.0

时间复杂度:O(1)

返回值:

给定域的值。

当给定域不存在或是给定 key 不存在时,返回 nil

127.0.0.1:6379> hgetall user1) "name"2) "zhangsan"127.0.0.1:6379> hget user name // field域存在"zhangsan"127.0.0.1:6379> hget user age // field域不存在(nil)127.0.0.1:6379> hget person name // key不存在(nil)

4.HGETALL

HGETALL key

返回哈希表 key

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

可用版本:>= 2.0.0

时间复杂度:O(N), N

返回值:

以列表形式返回哈希表的域和域的值。

若 key

127.0.0.1:6379> hgetall person // key不存在(empty list or set)127.0.0.1:6379> hgetall user1) "name" // field域2) "zhangsan" // 值

5.HINCRBY

HINCRBY key field increment

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

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

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

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

对一个储存字符串值的域 field 执行 HINCRBY

本操作的值被限制在 64 位(bit)有符号数字表示之内。

可用版本:>= 2.0.0

时间复杂度:O(1)

返回值:执行 HINCRBY 命令之后,哈希表 key 中域 field

# increment 为正数redis> HEXISTS counter page_view # 对空域进行设置(integer) 0redis> HINCRBY counter page_view 200(integer) 200redis> HGET counter page_view"200"# increment 为负数redis> HGET counter page_view"200"redis> HINCRBY counter page_view -50(integer) 150redis> HGET counter page_view"150"# 尝试对字符串值的域执行HINCRBY命令redis> HSET myhash string hello,world # 设定一个字符串值(integer) 1redis> HGET myhash string"hello,world"redis> HINCRBY myhash string 1 # 命令执行失败,错误。(error) ERR hash value is not an integerredis> HGET myhash string # 原值不变"hello,world"

6.HINCRBYFLOAT

HINCRBYFLOAT key field increment

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

如果哈希表中没有域 field ,那么 HINCRBYFLOAT 会先将域 field 的值设为 0

如果键 key 不存在,那么 HINCRBYFLOAT 会先创建一个哈希表,再创建域 field

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

域 field域 field 当前的值或给定的增量 increment

HINCRBYFLOAT 命令的详细功能和 INCRBYFLOAT 命令类似,请查看 INCRBYFLOAT

可用版本:>= 2.6.0

时间复杂度:O(1)

返回值:执行加法操作之后 field

# 值和增量都是普通小数redis> HSET mykey field 10.50(integer) 1redis> HINCRBYFLOAT mykey field 0.1"10.6"# 值和增量都是指数符号redis> HSET mykey field 5.0e3(integer) 0redis> HINCRBYFLOAT mykey field 2.0e2"5200"# 对不存在的键执行 HINCRBYFLOATredis> EXISTS price(integer) 0redis> HINCRBYFLOAT price milk 3.5"3.5"redis> HGETALL price1) "milk"2) "3.5"# 对不存在的域进行 HINCRBYFLOATredis> HGETALL price1) "milk"2) "3.5"redis> HINCRBYFLOAT price coffee 4.5 # 新增 coffee 域"4.5"redis> HGETALL price1) "milk"2) "3.5"3) "coffee"4) "4.5"

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Apollo(阿波罗)是携程框架部门研发的配置管理平台
下一篇:Redis教程9-哈希(Hash)常用命令使用参考2
相关文章

 发表评论

暂时没有评论,来抢沙发吧~