散列
就像一个减配的Redis
内部及其类似Java的Map
内容就是
key
:value
结构
hash
类型在面向对象编程的运用中及其适合,因为它可以直接保存编程语言中的实体类关系
增
hset
hset key field value
设置key
指定的哈希集字段的值
127.0.0.1:6379> hset user name zhangsan
(integer) 1
127.0.0.1:6379> hset user age 23
(integer) 1
127.0.0.1:6379> hset user address china
(integer) 1
hsetnx
hsetnx key field value
真正的哈希添加方法,如果field
不存在则添加
h
hmset
hmset key field1 value1 [field2 value2]
hset
的批量操作
127.0.0.1:6379> hmset zhangsan name zhangsan age 19 address hunan
OK
查
hget
hget key field
查询指定key
的某个字段的值
127.0.0.1:6379> hget user name
"zhangsan"
hexiste
hexists key field
判断key
中是否存在某个字段
127.0.0.1:6379> hexists user name
(integer) 1
127.0.0.1:6379> hexists user name2
(integer) 0
hkeys
hkeys key
返回哈希中所有的字段名
hvals
hvals key
返回哈希中所有的value
hgetall
hgetall key
获取哈希中所有的字段和值
127.0.0.1:6379> hgetall user
1) "name"
2) "zhangsan"
3) "age"
4) "23"
5) "address"
6) "china"
hlen
hlen key
查询哈希的字段数量
hstrlen
hstrlen key field
查询某个字段的值的长度
修改
hset
修改某个字段的命令也是hset
如果
hset
操作执行的field
字段之前已经存在值,那么就相当于修改存在
127.0.0.1:6379> hset user name "zhangwuji"
(integer) 0 #虽然把那么修改了,但是因为这个命令没有对hash内部做添加操作,返回值是新添加数量,所以这里是0
hincrby
hincrby key field incremment
将哈希内部的某个整数字段的值自加,incremment
为增量
127.0.0.1:6379> hincrby user skill 1
(integer) 11
127.0.0.1:6379> hincrby user skill 1
(integer) 12
hincrbyfloat
hincrbyfloatkey field incremment
将哈希内部的某个浮点字段的值自加,incremment
为增量
删除
hdel
hdel key field1 field2 ...
删除哈希中n个字段