盛年不重来,一日难再晨,及时当勉励,岁月不待人。这篇文章主要讲述Redis 数据类型介绍相关的知识,希望能为你提供帮助。
Redis 数据类型参考资料:http://www.redis.cn/topics/data-types.html
相关命令参考: http://redisdoc.com/
类型 | 简介 | 特性 | 场景 |
---|---|---|---|
String(字符串) | 二进制安全 | 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M | --- |
Hash(字典) | 键值对集合,即编程语言中的Map类型 | 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去) | 存储、读取、修改用户属性 |
List(列表) | 链表(双向链表) | 增删快,提供了操作某一段元素的API | 1,最新消息排行等功能(比如朋友圈的时间线) 2,消息队列 |
Set(集合) | 哈希表实现,元素不重复 | 1、添加、删除,查找的复杂度都是O(1) 2、为集合提供了求交集、并集、差集等操作 | 1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐 |
Sorted Set(有序集合) | 将Set中的元素增加一个权重参数score,元素按score有序排列 | 数据插入集合时,已经进行天然排序 | 1、排行榜 2、带权重的消息队列 |
字符串是所有编程语言中最常见的和最常用的数据类型,而且也是redis最基本的数据类型之一,而且redis 中所有的 key 的类型都是字符串。常用于保存 Session 信息场景,此数据类型比较常用
命令 | 含义 | 复杂度 |
---|---|---|
Set key value | 设置key-value | o(1) |
Get key | 获取key-value | o(1) |
Del key | 删除key-value | o(1) |
Setnx setxx | 根据key是否存在设置key-value | o(1) |
Incr decr | 计数 | o(1) |
Mget mset | 批量操作key-value | o(n) |
- set 指令可以创建一个key 并赋值, 使用格式
SET key value [EX seconds] [PX milliseconds] [NX|XX]
时间复杂度: O(1)
将字符串值 value 关联到 key 。如果 key 已经持有其他值, SET 就覆写旧值, 无视类型。
当 SET 命令对一个带有生存时间(TTL)的键进行设置之后, 该键原有的 TTL 将被清除。从 Redis 2.6.12 版本开始, SET 命令的行为可以通过一系列参数来修改:
EX seconds : 将键的过期时间设置为 seconds 秒。 执行 SET key value EX seconds 的效果等 同于执行 SETEX key seconds value 。
PX milliseconds : 将键的过期时间设置为 milliseconds 毫秒。 执行 SET key value PX milliseconds 的效果等同于执行 PSETEX key milliseconds value 。
NX : 只在键不存在时, 才对键进行设置操作。 执行 SET key value NX 的效果等同于执行 SETNX key value 。
XX : 只在键已经存在时, 才对键进行设置操作。
- 范例
#不论key是否存在.都设置
127.0.0.1:6379>
set key1 value1
OK
127.0.0.1:6379>
get key1
"value1"
127.0.0.1:6379>
TYPE key1 #判断类型
string
127.0.0.1:6379>
SET title ceo ex 3 #设置自动过期时间3s OK
127.0.0.1:6379>
set NAME wang
OK
127.0.0.1:6379>
get NAME
"wang"
#大小写敏感
127.0.0.1:6379>
get name (nil)
127.0.0.1:6379>
set name mage OK
127.0.0.1:6379>
get name "mage"
127.0.0.1:6379>
get NAME "wang"
#key不存在,才设置,相当于add
127.0.0.1:6379>
get title
"ceo"
127.0.0.1:6379>
setnx title coo #set key value nx (integer) 0
127.0.0.1:6379>
get title
"ceo"
#key存在,才设置,相当于update 127.0.0.1:6379>
get title
"ceo"
127.0.0.1:6379>
set title coo xx OK
127.0.0.1:6379>
get title
"coo"
127.0.0.1:6379>
get age
(nil)
127.0.0.1:6379>
set age 20 xx
(nil)
127.0.0.1:6379>
get age
(nil)
1.1.2 获取key内容
127.0.0.1:6379>
get key1
"value1"
127.0.0.1:6379>
get name age
(error) ERR wrong number of arguments for \'get\' command
1.1.3 删除key
127.0.0.1:6379>
DEL key1
(integer) 1
127.0.0.1:6379>
DEL key1 key2
(integer) 2
1.1.4 批量设置多个key
127.0.0.1:6379>
MSET key1 value1 key2 value2
OK
1.1.5 批量获取多个key
127.0.0.1:6379>
MGET key1 key2
1) "value1"
2) "value2"
127.0.0.1:6379>
KEYS n*
1) "n1"
2) "name"
127.0.0.1:6379>
KEYS *
1) "k2"
2) "k1"
3) "key1"
4) "key2"
5) "n1"
6) "name"
7) "k3"
8) "title"
1.1.6 追加数据
127.0.0.1:6379>
APPEND key1 " append new value"
(integer) 12 #添加数据后,key1总共9个字节
127.0.0.1:6379>
get key1
"value1 append new value"
1.1.7 设置新值并返回旧值
#set key newvalue并返回旧的value
127.0.0.1:6379>
set name wang
OK
127.0.0.1:6379>
getset name 123
"wang"
127.0.0.1:6379>
get name
"test"
1.1.8 返回字符串key对应的字节数
127.0.0.1:6379>
SET name wang
OK
127.0.0.1:6379>
STRLEN name
(integer) 4
127.0.0.1:6379>
APPEND name " xiaochun"
(integer) 13
127.0.0.1:6379>
GET name
"wang xiaochun"
127.0.0.1:6379>
STRLEN name #返回字节数
(integer) 13
127.0.0.1:6379>
set name test
OK
127.0.0.1:6379>
get name
"\\xe9\\xa9\\xac\\xe5\\x93\\xa5\\xe6\\x95\\x99\\xe8\\x82\\xb2"
127.0.0.1:6379>
strlen name
(integer) 12
127.0.0.1:6379>
1.1.9 判断key是否存在
127.0.0.1:6379>
SET name wang ex 10
OK
127.0.0.1:6379>
set age 20
OK
127.0.0.1:6379>
EXISTS NAME #key的大小写敏感
(integer) 0
127.0.0.1:6379>
EXISTS name age #返回值为1,表示存在2个key,0表示不存在 (integer) 2
127.0.0.1:6379>
EXISTS name #过几秒再看
(integer) 0
1.1.10 查看key过期时间
ttl key #查看key的剩余生存时间,如果key过期后,会自动删除
-1 #返回值表示永不过期,默认创建的key是永不过期,重新对key赋值,也会从有剩余生命周期变成永不过 期
-2 #返回值表示没有此key
num #key的剩余有效期
127.0.0.1:6379>
TTL key1
(integer) -1
127.0.0.1:6379>
SET name wang EX 100
OK
127.0.0.1:6379>
TTL name
(integer) 96
127.0.0.1:6379>
TTL name
(integer) 93
127.0.0.1:6379>
SET name
OK
mage #重新设置,默认永不过期
127.0.0.1:6379>
TTL name
(integer) -1
127.0.0.1:6379>
SET name wang EX 200
OK
127.0.0.1:6379>
TTL name
(integer) 198
127.0.0.1:6379>
GET name
"wang"
1.1.11 重新设置key的过期时间
127.0.0.1:6379>
TTL name
(integer) 148
127.0.0.1:6379>
EXPIRE name 1000
(integer) 1
127.0.0.1:6379>
TTL name
(integer) 999
127.0.0.1:6379>
1.1.12 取消key的过期时间
127.0.0.1:6379>
TTL name
(integer) 999
127.0.0.1:6379>
PERSIST name
(integer) 1
127.0.0.1:6379>
TTL name
(integer) -1
1.1.13 数值递增
- 利用INCR命令簇(INCR, DECR, INCRBY,DECRBY)来把字符串当作原子计数器使用。
127.0.0.1:6379>
set num 10 #设置初始值 OK
127.0.0.1:6379>
INCR num
(integer) 11
127.0.0.1:6379>
get num
"11"
1.1.14 数值递减
127.0.0.1:6379>
set num 10
OK
127.0.0.1:6379>
DECR num
(integer) 9
127.0.0.1:6379>
get num
"9"
1.1.15 数值增加
- 将key对应的数字加decrement(可以是负数)。如果key不存在,操作之前,key就会被置为0。如果key 的value类型错误或者是个不能表示成数字的字符串,就返回错误。这个操作最多支持64位有符号的正 型数字。
redis>
SET mykey 10
OK
redis>
INCRBY mykey 5
(integer) 15
127.0.0.1:6379>
get mykey
"15"
127.0.0.1:6379>
INCRBY mykey -10
(integer) 5
127.0.0.1:6379>
get mykey
"5"
127.0.0.1:6379>
INCRBY nokey5
(integer) 5
127.0.0.1:6379>
get nokey
"5"
1.1.16 数据减少
- decrby 可以减小数值(也可以增加)
127.0.0.1:6379>
SET mykey 10
OK
127.0.0.1:6379>
DECRBY mykey 8
(integer) 2
127.0.0.1:6379>
get mykey
"2"
127.0.0.1:6379>
DECRBY mykey -20
(integer) 22
127.0.0.1:6379>
get mykey
"22"
127.0.0.1:6379>
DECRBY nokey 3
(integer) -3
127.0.0.1:6379>
get nokey
"-3"
1.5.2 列表 list
文章图片
- 列表是一个双向可读写的管道,其头部是左侧,尾部是右侧,一个列表最多可以包含2^32- 1(4294967295)个元素,下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。 也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,元素值可以重 复,常用于存入日志等场景,此数据类型比较常用
- 列表特点
- 有序
- 可重复
- 左右都可操作
- LPUSH和RPUSH都可以插入列表
LPUSH key value [value …]
时间复杂度: O(1)
将一个或多个值 value 插入到列表 key 的表头如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头: 比如说,对空列表
mylist 执行命令 LPUSH mylist a b c ,列表的值将是 c b a ,这等同于原子性地执行 LPUSH
mylist a 、 LPUSH mylist b 和 LPUSH mylist c 三个命令。如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。
当 key 存在但不是列表类型时,返回一个错误。
RPUSH key value [value …]
时间复杂度: O(1)
将一个或多个值 value 插入到列表 key 的表尾(最右边)。如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表尾:比如对一个空列表
mylist 执行 RPUSH mylist a b c ,得出的结果列表为 a b c ,等同于执行命令 RPUSH mylist
a 、 RPUSH mylist b 、 RPUSH mylist c 。如果 key 不存在,一个空列表会被创建并执行 RPUSH 操作。
当 key 存在但不是列表类型时,返回一个错误。
- 范例
#从左边添加数据,已添加的需向右移
127.0.0.1:6379>
LPUSH name mage wang zhang #根据顺序逐个写入name,最后的zhang会在列表的最左侧。
(integer) 3
127.0.0.1:6379>
TYPE name
list#从右边添加数据
127.0.0.1:6379>
RPUSH course linux python go
(integer) 3
127.0.0.1:6379>
type course
list
1.5.2.2向列表追加数据
127.0.0.1:6379>
LPUSH list1 tom
(integer) 2
#从右边添加数据,已添加的向左移
127.0.0.1:6379>
RPUSH list1 jack
(integer) 3
1.5.2.3 获取列表长度(元素个数)
127.0.0.1:6379>
LLEN list1
(integer) 3
1.5.2.4 获取列表指定位置数据【Redis 数据类型介绍】
文章图片
文章图片
文章图片
127.0.0.1:6379>
LPUSH list1 a b c d
(integer) 4
127.0.0.1:6379>
LINDEX list1 0 #获取0编号的元素
"d"
127.0.0.1:6379>
LINDEX list1 3 #获取3编号的元素
"a"
127.0.0.1:6379>
LINDEX list1 -1 #获取最后一个的元素
"a"
#元素从0开始编号
127.0.0.1:6379>
LPUSH list1 a b c d
(integer) 4
127.0.0.1:6379>
LRANGE list1 1 2
1) "c"
2) "b"
127.0.0.1:6379>
LRANGE list1 0 3 #所有元素
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379>
LRANGE list1 0 -1 #所有元素
1) "d"
2) "c"
3) "b"
4) "a"127.0.0.1:6379>
RPUSH list2 zhang wang li zhao
(integer) 4
127.0.0.1:6379>
LRANGE list2 1 2 #指定范围
1) "wang"
2) "li"
127.0.0.1:6379>
LRANGE list2 2 2 #指定位置
1) "li"
127.0.0.1:6379>
LRANGE list2 0 -1 #所有元素
1) "zhang"
2) "wang"
3) "li"
4) "zhao"
1.5.2.5 获取列表指定索引值
127.0.0.1:6379>
RPUSH listkey a b c d e f
(integer) 6
127.0.0.1:6379>
lrange listkey 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
5) "e"
6) "f"
127.0.0.1:6379>
lset listkey 2 java
OK
127.0.0.1:6379>
lrange listkey 0 -1
1) "a"
2) "b"
3) "java"
4) "d"
5) "e"
6) "f"
127.0.0.1:6379>
1.5.2.6 移除列表数据
127.0.0.1:6379>
LPUSH list1 a b c d
(integer) 4
127.0.0.1:6379>
LRANGE list1 0 3
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379>
LPOP list1 #弹出左边第一个元素,即删除第一个
"d"
127.0.0.1:6379>
LLEN list1
(integer) 3
127.0.0.1:6379>
LRANGE list1 0 2
1) "c"
2) "b"
3) "a"
127.0.0.1:6379>
RPOP list1 #弹出右边第一个元素,即删除最后一个
"a"
127.0.0.1:6379>
LLEN list1
(integer) 2
127.0.0.1:6379>
LRANGE list1 0 1
1) "c"
2) "b"#LTRIM 对一个列表进行修剪(trim),让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删
除
127.0.0.1:6379>
LLEN list1
(integer) 4
127.0.0.1:6379>
LRANGE list1 0 3
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379>
LTRIM list1 1 2 #只保留1,2号元素
OK
127.0.0.1:6379>
LLEN list1
(integer) 2
127.0.0.1:6379>
LRANGE list1 0 1
1) "c"
2) "b"
#删除list
127.0.0.1:6379>
DEL list1
(integer) 1
127.0.0.1:6379>
EXISTS list1
(integer) 0
1.5.3 集合setSet 是 String 类型的无序集合,集合中的成员是唯一的,这就意味着集合中不能出现重复的数据,可以
在两个不同的集合中对数据进行对比并取值,常用于取值判断,统计,交集等场景
集合特点
- 无序
- 无重复
- 集合间操作
127.0.0.1:6379>
SADD set1 v1
(integer) 1
127.0.0.1:6379>
SADD set2 v2 v4
(integer) 2
127.0.0.1:6379>
TYPE set1
set
127.0.0.1:6379>
TYPE set2
set
1.5.3.2 追加数值
#追加时,只能追加不存在的数据,不能追加已经存在的数值
127.0.0.1:6379>
SADD set1 v2 v3 v4
(integer) 3
127.0.0.1:6379>
SADD set1 v2 #已存在的value,无法再次添加
(integer) 0
127.0.0.1:6379>
TYPE set1
set
127.0.0.1:6379>
TYPE set2
set
1.5.3.3 查看集合的所有数据
127.0.0.1:6379>
SMEMBERS set1
1) "v4"
2) "v1"
3) "v3"
4) "v2"
127.0.0.1:6379>
SMEMBERS set2
1) "v4"
2) "v2"
1.5.3.4 删除集合的元素
127.0.0.1:6379>
sadd goods mobile laptop car
(integer) 3
127.0.0.1:6379>
srem goods car
(integer) 1
127.0.0.1:6379>
SMEMBERS goods
1) "mobile"
2) "laptop"
127.0.0.1:6379>
1.5.3.5 获取集合的交集
- 交集:已属于A且属于B的元素称为A与B的交(集
127.0.0.1:6379>
SINTER set1 set2
1) "v4"
2) "v2"
1.5.3.6 获取集合的并集
- 并集:已属于A或属于B的元素为称为A与B的并(集)
127.0.0.1:6379>
SUNION set1 set2
1) "v2"
2) "v4"
3) "v1"
4) "v3"
1.5.3.7 获取集合的差集
- 差集:已属于A而不属于B的元素称为A与B的差(集)
127.0.0.1:6379>
SDIFF set1 set2
1) "v1"
2) "v3"
1.5.4 有序集合 sorted set
- Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员,不同的是每个元素都会关
联一个double(双精度浮点型)类型的分数,redis正是通过该分数来为集合中的成员进行从小到大的排
序,有序集合的成员是唯一的,但分数(score)却可以重复,集合是通过哈希表实现的,所以添加,删
除,查找的复杂度都是O(1), 集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个
成员),经常用于排行榜的场景 - 有序集合特点
- 有序
- 无重复元素
- 每个元素是由score和value组成
- score 可以重复
- value 不可以重复
127.0.0.1:6379>
ZADD zset1 1 v1 #分数为1
(integer) 1
127.0.0.1:6379>
ZADD zset1 2 v2
(integer) 1
127.0.0.1:6379>
ZADD zset1 2 v3 #分数可重复,元素值不可以重复
(integer) 1
127.0.0.1:6379>
ZADD zset1 3 v4
(integer) 1
127.0.0.1:6379>
TYPE zset1
zset
127.0.0.1:6379>
TYPE zset2
zset
#一次生成多个数据:
127.0.0.1:6379>
ZADD zset2 1 v1 2 v2 3 v3 4 v4 5 v5
(integer) 5
1.5.4.2 有序集合实现排行榜
127.0.0.1:6379>
ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia
(integer) 4
127.0.0.1:6379>
ZRANGE paihangbang 0 -1 #正序排序后显示集合内所有的key,score从小到大
显示
1) "gangtiexia"
2) "zhuluoji"
3) "nezha"
4) "zhanlang"
127.0.0.1:6379>
ZREVRANGE paihangbang 0 -1 #倒序排序后显示集合内所有的key,score从大到
小显示
1) "zhanlang"
2) "nezha"
3) "zhuluoji"
4) "gangtiexia"
127.0.0.1:6379>
ZRANGE paihangbang 0 -1 WITHSCORES #正序显示指定集合内所有key和得分
情况
1) "gangtiexia"
2) "30"
3) "zhuluoji"
4) "60"
5) "nezha"
6) "90"
7) "zhanlang"
8) "199"
127.0.0.1:6379>
ZREVRANGE paihangbang 0 -1 WITHSCORES #倒序显示指定集合内所有key和
得分情况
1) "zhanlang"
2) "199"
3) "nezha"
4) "90"
5) "zhuluoji"
6) "60"
7) "gangtiexia"
8) "30"
127.0.0.1:6379>
1.5.4.3 获取集合的个数
127.0.0.1:6379>
ZCARD paihangbang
(integer) 4
127.0.0.1:6379>
ZCARD zset1
(integer) 4
127.0.0.1:6379>
ZCARD zset2
(integer) 4
1.5.4.4 基于索引返回数值
127.0.0.1:6379>
ZRANGE paihangbang 0 2
1) "gangtiexia"
2) "zhuluoji"
3) "nezha"
127.0.0.1:6379>
ZRANGE paihangbang 0 10 #超出范围不报错
1) "gangtiexia"
2) "zhuluoji"
3) "nezha"
4) "zhanlang"
127.0.0.1:6379>
ZRANGE zset1 1 3
1) "v2"
2) "v3"
3) "v4"
127.0.0.1:6379>
ZRANGE zset1 0 2
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379>
ZRANGE zset1 2 2
1) "v3"
1.5.4.5 返回某个数值的索引(排名)
127.0.0.1:6379>
ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia
(integer) 4
127.0.0.1:6379>
ZRANK paihangbang zhanlang
(integer) 3 #第4个
127.0.0.1:6379>
ZRANK paihangbang zhuluoji
(integer) 1 #第2个
1.5.4.6 获取分数
127.0.0.1:6379>
zscore paihangbang gangtiexia
"30"
1.5.4.7 删除元素
127.0.0.1:6379>
ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia
(integer) 4
127.0.0.1:6379>
ZRANGE paihangbang 0 -1
1) "gangtiexia"
2) "zhuluoji"
3) "nezha"
4) "zhanlang"
127.0.0.1:6379>
ZREM paihangbang zhuluoji zhanlang
(integer) 2
127.0.0.1:6379>
ZRANGE paihangbang 0 -1
1) "gangtiexia"
2) "nezha"
1.5.5 哈希hashhash 是一个string类型的字段(field)和值(value)的映射表,Redis 中每个 hash 可以存储 2^32 -1 键值
对,类似于字典,存放了多个k/v 对,hash特别适合用于存储对象场景
1.5.5.1 生成hash key
- 格式:
HSET hash field value
时间复杂度: O(1)
将哈希表 hash 中域 field 的值设置为 value 。
如果给定的哈希表并不存在, 那么一个新的哈希表将被创建并执行 HSET 操作。
如果域 field 已经存在于哈希表中, 那么它的旧值将被新值 value 覆盖。
127.0.0.1:6379>
HSET 9527 name zhouxingxing age 20
(integer) 2
127.0.0.1:6379>
TYPE 9527
hash
#查看所有字段的值
127.0.0.1:6379>
hgetall 9527
1) "name"
2) "zhouxingxing"
3) "age"
4) "20"
#增加字段
127.0.0.1:6379>
HSET 9527 gender male
(integer) 1
127.0.0.1:6379>
hgetall 9527
1) "name"
2) "zhouxingxing"
3) "age"
4) "20"
5) "gender"
6) "male"
1.5.5.2 获取hash对应字段值
127.0.0.1:6379>
HGET 9527 name
"zhouxingxing"
127.0.0.1:6379>
HGET 9527 age
"20"
127.0.0.1:6379>
HMGET 9527 name age #获取多个值
1) "zhouxingxing"
2) "20"
127.0.0.1:6379>
1.5.5.3 删除hash 对应字段
127.0.0.1:6379>
HDEL 9527 age
(integer) 1
127.0.0.1:6379>
HGET 9527 age
(nil)
127.0.0.1:6379>
hgetall 9527
1) "name"
2) "zhouxingxing"
127.0.0.1:6379>
HGET 9527 name
"zhouxingxing"
1.5.5.4 批量设置hash key的多个field和value
127.0.0.1:6379>
HMSET 9527 name zhouxingxing age 50 city hongkong
OK
127.0.0.1:6379>
HGETALL 9527
1) "name"
2) "zhouxingxing"
3) "age"
4) "50"
5) "city"
6) "hongkong"
1.5.5.5 获取hash中指定字段的值
127.0.0.1:6379>
HMSET 9527 name zhouxingxing age 50 city hongkong
OK
127.0.0.1:6379>
HMGET 9527 name age
1) "zhouxingxing"
2) "50"
127.0.0.1:6379>
1.5.5.6 获取hash中的所有字段名field
127.0.0.1:6379>
HMSET 9527 name zhouxingxing age 50 city hongkong #重新设置
OK
127.0.0.1:6379>
HKEYS 9527
1) "name"
2) "age"
3) "city"
1.5.5.7 获取hash key对应所有field的value
127.0.0.1:6379>
HMSET 9527 name zhouxingxing age 50 city hongkong
OK
127.0.0.1:6379>
HVALS 9527
1) "zhouxingxing"
2) "50"
3) "hongkong"
1.5.5.8 获取指定hash key 的所有field及value
127.0.0.1:6379>
HGETALL 9527
1) "name"
2) "zhouxingxing"
3) "age"
4) "50"
5) "city"
6) "hongkong"
127.0.0.1:6379>
1.5.5.9 删除hash
127.0.0.1:6379>
DEL 9527
(integer) 1
127.0.0.1:6379>
HMGET 9527 name city
1) (nil)
2) (nil)
127.0.0.1:6379>
EXISTS 9527
(integer) 0
推荐阅读
- 已经安装好的gitlab汉化
- linux dmidecode 获取CPU ID等系统硬件信息
- 手把手搭建单域多站点企业IT实战环境系列课程之第三季(基于VLMCSD搭建二合一KMS激活服务器)
- K8S疏散错误
- 软件测试必备Linux(21天掌握Linux命令 chmod)
- ubuntu-nfs
- 主机批量执行指令脚本工具推荐——WGCLOUD
- traefik透传用户端的真实ip(基于k8s平台)
- Linux之seq命令