前端框架选型是企业提升开发效率与用户体验的关键因素
642
2022-10-17
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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~