Redis 哈希(hash)
Redis hash 是一个 string 类型的 field(字段) 和 value(值) 的映射表,hash 特别适合用于存储对象。
Redis 中每个 hash 可以存储 232 - 1 键值对(40 多亿)。
Redis hash 命令
/*
将哈希表 key 中的字段 field 的值设为 value 。
如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。
如果字段已经存在于哈希表中,旧值将被覆盖。
如果字段是哈希表中的一个新建字段,值设置成功,返回 1。如果哈希表中域字段已经存在且旧值已被新值覆盖,返回 0
*/
HSET key field value
/*
获取存储在哈希表中指定字段的值。
返回给定字段的值。如果给定的字段或 key 不存在时,返回 nil 。
*/
HGET key field
/*
获取所有给定字段的值
如果指定的字段不存在于哈希表,那么返回一个 nil 值。
一个包含多个给定字段关联值的表,表值的排列顺序和指定字段的请求顺序一样。
*/
HMGET key field1 [field2]
/*
同时将多个 field-value (域-值)对设置到哈希表 key 中。
此命令会覆盖哈希表中已存在的字段。
如果哈希表不存在,会创建一个空哈希表,并执行 HMSET 操作。
*/
HMSET key field1 value1 [field2 value2 ]
/*
获取在哈希表中指定 key 的所有字段和值
在返回值里,紧跟每个字段名(field name)之后是字段的值(value)
以列表形式返回哈希表的字段及字段值。 若 key 不存在,返回空列表。
*/
HGETALL key
/*
查看哈希表 key 中,指定的字段是否存在。
如果哈希表含有给定字段,返回 1 。 如果哈希表不含有给定字段,或 key 不存在,返回 0 。
*/
HEXISTS key field
/*
只有在字段 field 不存在时,设置哈希表字段的值。
如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。
如果字段已经存在于哈希表中,操作无效。
如果 key 不存在,一个新哈希表被创建并执行 HSETNX 命令。
设置成功,返回 1 。 如果给定字段已经存在且没有操作被执行,返回 0 。
*/
HSETNX key field value
/*
获取哈希表中的所有字段,当 key 不存在时,返回一个空列表
*/
HKEYS key
/*
获取哈希表中所有值。
*/
HVALS key
/*
获取哈希表中字段的数量, 当 key 不存在时,返回 0 。
*/
HLEN key
/*
删除一个或多个哈希表字段,不存在的字段将被忽略。
返回被成功删除字段的数量,不包括被忽略的字段。
*/
HDEL key field1 [field2]
/*
为哈希表 key 中的指定字段的整数值加上增量 increment 。
增量也可以为负数,相当于对指定字段进行减法操作。
如果哈希表的 key 不存在,一个新的哈希表被创建并执行 HINCRBY 命令。
如果指定的字段不存在,那么在执行命令前,字段的值被初始化为 0 。
对一个储存字符串值的字段执行 HINCRBY 命令将造成一个错误。
*/
HINCRBY key field increment
/*
为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
如果指定的字段不存在,那么在执行命令前,字段的值被初始化为 0 。
返回执行命令之后的值
*/
HINCRBYFLOAT key field increment
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
编辑 (opens new window)
上次更新: 7/2/2024, 11:06:45 AM