【我与Redis的相爱相杀】详细讲解Redis五大常用数据类型在Linux系统下命令行代码的使用

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 【我与Redis的相爱相杀】详细讲解Redis五大常用数据类型在Linux系统下命令行代码的使用

一、基础操作

常用命令

keys * 查看当前库所有的key

exists key 判断某个key是否存在

type key 查看key是什么类型

del key 删除指定的key数据

unlink key 根据value选择非阻塞删除(真正的删除会在后续异步操作)

expire key 10 10秒钟:为给定的key设置过期时间

ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期

select 切换数据库

dbsize 查看当前数据库的key的数量

flushdb 清空当前库

flushall 通杀全部库

代码实现

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
127.0.0.1:6379> exists k1
(integer) 1
127.0.0.1:6379> type k1
string
127.0.0.1:6379> del k2
(integer) 1
127.0.0.1:6379> keys *
1) "k1"


可以看到,set 用于创建键值对,del、exists、type等命令行都可以正常操作


127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> keys * 
1) "k2"
2) "k1"
127.0.0.1:6379> unlink k2
(integer) 1
127.0.0.1:6379> keys *
1) "k1"
127.0.0.1:6379> expire k1 5
(integer) 1
127.0.0.1:6379> ttl k1
(integer) -2
127.0.0.1:6379> keys *
(empty array)


unlink命令在查找时,会发现是删除了的,但真正的删除会在后续异步操作;expire命令是设置key的过期时间,ttl是查看是否过期;过期了,意味着键值对的删除


二、字符串(String)

简介

String是Redis最基本的类型,一个key对应一个value

String类型是二进制安全的。意味着Redis的string可以包含任何数据,比如jpg图片或者序列化的对象。

String类型是Redis最基本的数据类型,一个Redis中字符串value最多可以是512M


常用命令

set <key><value> 添加键值对

get <key> 查询对应键值对

append <key><value> 将给定的value追加到原值的末尾

strlen <key> 获得值的长度

setnx <key><value> 只有在 key 不存在时 ,设置 key 的值

incr <key>将 key 中储存的数字值增1,只能对数字值操作,如果为空,新增值为1

decr <key>将 key 中储存的数字值减1,只能对数字值操作,如果为空,新增值为-1

incrby / decrby <key><步长> 将 key 中储存的数字值增减。自定义步长。

mset <key1><value1><key2><value2> .....同时设置一个或多个 key-value

mget <key1><key2><key3> .....同时获取一个或多个 value 原子性,有一个失败都失败

msetnx <key1><value1><key2><value2> .....同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在

getrange <key><起始位置><结束位置>获得值的范围

setrange <key><起始位置><value>用 value 覆写key所储存的字符串值,从<起始位置>开始(索引从0开始)

setex <key><过期时间><value>设置键值的同时,设置过期时间,单位秒

getset <key><value>以新换旧,设置了新值同时获得旧值

代码实现

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> append k1 "111"
(integer) 5
127.0.0.1:6379> get k1
"v1111"
127.0.0.1:6379> strlen k1
(integer) 5
127.0.0.1:6379> setnx k4 v4
(integer) 1


通过代码演示,可以了解到相应命令的用法


127.0.0.1:6379> set k1 1
OK
127.0.0.1:6379> incr k1
(integer) 2
127.0.0.1:6379> get k1
"2"
127.0.0.1:6379> decr k1
(integer) 1
127.0.0.1:6379> get k1
"1"
127.0.0.1:6379> incrby k1 4
(integer) 5
127.0.0.1:6379> get k1
"5"
127.0.0.1:6379> decrby k1 4
(integer) 1
127.0.0.1:6379> get k1
"1"



上面代码研究的是自增自减相关的命令行,用起来还是很简单,很容易理解的


127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> mget k1 k2 k3
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> msetnx k4 v4 k5 v5
(integer) 1
127.0.0.1:6379> mget k4 k5
1) "v4"
2) "v5"
127.0.0.1:6379> getrange k1 0 2
"v1"
127.0.0.1:6379> setrange k1 0 v1111
(integer) 5
127.0.0.1:6379> get k1
"v1111"
127.0.0.1:6379> getset k1 v1
"v1111"
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> setex k1 5 v111
OK
127.0.0.1:6379> get k1
"v111"



以上代码演示的是多个键值对的设置以及多个键值对的获取,也是很容易理解的


三、列表(List)

简介

Redis 列表是简单的字符串列表,按照插入顺序排序。可以添加一个元素到列表的头部(左边)或者尾部(右边)


常用命令

lpush/rpush <key><value1><value2><value3> .... 从左边/右边插入一个或多个值。

lpop/rpop <key>从左边/右边吐出一个值。值在键在,值光键亡。

rpoplpush <key1><key2>从<key1>列表右边吐出一个值,插到key2列表左边。

lrange <key><start><stop>按照索引下标获得元素(从左到右)

lrange mylist 0 -1 0左边第一个,-1右边第一个,(0-1表示获取所有)

lindex <key><index>按照索引下标获得元素(从左到右)

llen <key>获得列表长度

linsert <key> before <value><newvalue>在value的后面插入newvalue插入值

lrem <key><n><value>从左边删除n个value(从左到右)

lset<key><index><value>将列表key下标为index的值替换成value

代码实现

127.0.0.1:6379> lpush k1 v11 v12 v13
(integer) 3
127.0.0.1:6379> lrange k1 0 -1
1) "v13"
2) "v12"
3) "v11"
127.0.0.1:6379> lpop k1
"v13"
127.0.0.1:6379> lpop k1
"v12"
127.0.0.1:6379> lpop k1
"v11"
127.0.0.1:6379> lrange k1 0 -1
(empty array)
127.0.0.1:6379> lpush k2 v21 v22 v23
(integer) 3



其中lrange k1 0 -1表示的是查看所有的key下的数据


127.0.0.1:6379> lpush k1 v11 v12 v13
(integer) 3
127.0.0.1:6379> rpoplpush k1 k2
"v11"
127.0.0.1:6379> lrange k2 0 -1
1) "v11"
2) "v23"
3) "v22"
4) "v21"
127.0.0.1:6379> lindex k2 0
"v11"
127.0.0.1:6379> llen k2
(integer) 4


可以通过下标获取key下的值,也可以通过llen来获取key下的长度


127.0.0.1:6379> lindex k2 0
"v11"
127.0.0.1:6379> llen k2
(integer) 4
127.0.0.1:6379> linsert k2 before v11 v10
(integer) 5
127.0.0.1:6379> lrange k2 0 -1
1) "v10"
2) "v11"
3) "v23"
4) "v22"
5) "v21"
127.0.0.1:6379> lrem k2 3 v10
(integer) 1
127.0.0.1:6379> lrange k2 0 -1
1) "v11"
2) "v23"
3) "v22"
4) "v21"
127.0.0.1:6379> lset k2 0 v00
OK
127.0.0.1:6379> lrange k2 0 -1
1) "v00"
2) "v23"
3) "v22"
4) "v21"



可以在key下的某个值前后插入新的值,组成新的列表


四、集合(Set)

简介

Redis set对外提供的功能与list类似是一个列表的功能,特殊之处在于set是可以自动排重的,当需要存储一个列表数据,又不希望出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。


常用命令

sadd <key><value1><value2> ..... 将一个或多个 member 元素加入到集合 key 中,已经存在的 member 元素将被忽略

smembers <key> 取出该集合的所有值。

sismember <key><value> 判断集合key是否为含有该value值,有1,没有0

scard<key> 返回该集合的元素个数。

srem <key><value1><value2> .... 删除集合中的某个元素。

spop <key> 随机从该集合中吐出一个值。

srandmember <key><n> 随机从该集合中取出n个值。不会从集合中删除 。

smove <source><destination>value 把集合中一个值从一个集合移动到另一个集合

sinter <key1><key2> 返回两个集合的交集元素。

sunion <key1><key2> 返回两个集合的并集元素。

sdiff <key1><key2> 返回两个集合的差集元素(key1中的,不包含key2中的)

代码实现

127.0.0.1:6379> sadd k1 v11 v12 v13 v11
(integer) 3
127.0.0.1:6379> smembers k1
1) "v12"
2) "v13"
3) "v11"
127.0.0.1:6379> sismember k1 v12
(integer) 1
127.0.0.1:6379> scard k1
(integer) 3
127.0.0.1:6379> srem k1 v12 v11
(integer) 2
127.0.0.1:6379> smembers k1
1) "v13"
127.0.0.1:6379> spop k1
"v13"
127.0.0.1:6379> smembers k1
(empty array)



这里的命令行其实跟列表List相差不多,不同的地方就是set集合中不能有重复值的出现


127.0.0.1:6379> sadd k1 v11 v22 v11 v33
(integer) 3
127.0.0.1:6379> sadd k2 v11 v44 v55
(integer) 3
127.0.0.1:6379> srandmember k1 2
1) "v11"
2) "v33"
127.0.0.1:6379> sinter k1 k2
1) "v11"
127.0.0.1:6379> sunion k1 k2
1) "v11"
2) "v44"
3) "v22"
4) "v33"
5) "v55"
127.0.0.1:6379> sdiff k1 k2 
1) "v22"
2) "v33"
127.0.0.1:6379> smove k1 k2 v22
(integer) 1
127.0.0.1:6379> smembers k2
1) "v11"
2) "v22"
3) "v44"
4) "v55"



主要涉及两个集合的操作:交集、并集和差集


五、哈希(Hash)

简介

Redis hash 是一个键值对集合

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

类似Java里面的Map<String,Object>


常用命令

hset <key><field><value>给集合中的 field键赋值value

hget <key1><field>从集合取出 value

hmset <key1><field1><value1><field2><value2>...批量设置hash的值

hexists<key1><field>查看哈希表 key 中,给定域 field 是否存在。

hkeys <key>列出该hash集合的所有field

hvals <key>列出该hash集合的所有value

hincrby <key><field><increment>为哈希表 key 中的域 field 的值加上增量 1 -1

hsetnx <key><field><value>将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在 .

代码实现

127.0.0.1:6379> hset user1 name tom
(integer) 1
127.0.0.1:6379> hget user1 name
"tom"
127.0.0.1:6379> hmset user1 password tom age 17
OK
127.0.0.1:6379> hexists user1 age
(integer) 1
127.0.0.1:6379> hkeys user1
1) "name"
2) "password"
3) "age"
127.0.0.1:6379> hvals user1
1) "tom"
2) "tom"
3) "17"
127.0.0.1:6379> hincrby user1 age 1
(integer) 18
127.0.0.1:6379> hset user1 password 12345
(integer) 0
127.0.0.1:6379> hset user1 phone 12345
(integer) 1
127.0.0.1:6379> hkeys user1
1) "name"
2) "password"
3) "age"
4) "phone"
127.0.0.1:6379> hvals user1
1) "tom"
2) "12345"
3) "18"
4) "12345"



从代码可以看到,hset user1 password 12345 会失败,需要注意一下


六、有序集合(Zset)

简介

Redis有序集合zset与普通集合set非常相似,是一个没有重复元素的字符串集合。

不同之处是有序集合的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分可以是重复的

因为元素是有序的, 所以你也可以很快的根据评分(score)或者次序(position)来获取一个范围的元素。

访问有序集合的中间元素也是非常快的,因此你能够使用有序集合作为一个没有重复成员的智能列表。


常用命令

zadd <key><score1><value1><score2><value2>… 将一个或多个 member 元素及其 score 值加入到有序集 key 当中

zrange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在 之间的元素 ,带 WITHSCORES,可以让分数一起和值返回到结果集

zrangebyscore key minmax [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列

zrevrangebyscore key maxmin [withscores] [limit offset count] 同上,改为从大到小排列

zincrby <key><increment><value> 为元素的score加上增量

zrem <key><value> 删除该集合下,指定值的元素

zcount <key><min><max> 统计该集合,分数区间内的元素个数

zrank <key><value> 返回该值在集合中的排名,从0开始

代码实现

127.0.0.1:6379> zadd book 23 java 15 c 66 php 10 c++
(integer) 4
127.0.0.1:6379> zrange book 0 -1
1) "c++"
2) "c"
3) "java"
4) "php"
127.0.0.1:6379> zrangebyscore book 25 88
1) "php"
127.0.0.1:6379> zincrby book 2 java
"25"
127.0.0.1:6379> zrem book c++ 
(integer) 1
127.0.0.1:6379> zcount book 0 88
(integer) 3
127.0.0.1:6379> zrank book php
(integer) 2
127.0.0.1:6379> zrank book c
(integer) 0



有序集合的特点跟哈希差不多,区别是有序集合的每个成员都关联了一个评分,评分是可以重复的,集合的成员是唯一的


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
18天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
7天前
|
缓存 NoSQL PHP
使用PHP-redis实现键空间通知监听key失效事件的技术与代码示例
通过上述方法,你可以有效地在PHP中使用Redis来监听键空间通知,特别是针对键失效事件。这可以帮助你更好地管理缓存策略,及时响应键的变化。
24 3
|
17天前
|
NoSQL Linux Redis
Linux Redis 服务设置开机自启动
【9月更文挑战第2天】在 Linux 系统中,可使用两种方法设置 Redis 开机自启动:一是通过创建 `redis.service` 文件并利用 systemd 进行管理,包括定义服务参数和启动脚本;二是编辑 `/etc/rc.local` 文件,在其中添加启动命令。推荐使用 systemd 方法,因为它更符合现代 Linux 系统的设计理念。设置完成后,可通过 `sudo systemctl status redis.service` 检查服务状态。
|
24天前
|
NoSQL Linux 编译器
内核实验(一):使用QEMU+GDB断点调试Linux内核代码
如何配置环境并使用QEMU虚拟机结合GDB进行Linux内核代码的断点调试,包括安装QEMU、交叉编译工具链,编译内核以及通过GDB远程连接进行调试的详细步骤。
29 0
内核实验(一):使用QEMU+GDB断点调试Linux内核代码
|
11天前
|
Linux 开发者 Python
从Windows到Linux,Python系统调用如何让代码飞翔🚀
【9月更文挑战第10天】在编程领域,跨越不同操作系统的障碍是常见挑战。Python凭借其“编写一次,到处运行”的理念,显著简化了这一过程。通过os、subprocess、shutil等标准库模块,Python提供了统一的接口,自动处理底层差异,使代码在Windows和Linux上无缝运行。例如,`open`函数在不同系统中以相同方式操作文件,而`subprocess`模块则能一致地执行系统命令。此外,第三方库如psutil进一步增强了跨平台能力,使开发者能够轻松编写高效且易维护的代码。借助Python的强大系统调用功能,跨平台编程变得简单高效。
13 0
|
19天前
|
机器学习/深度学习 Linux 开发工具
Linux内核开发流程指南 - 5. 编写正确的代码【ChatGPT】
Linux内核开发流程指南 - 5. 编写正确的代码【ChatGPT】
|
19天前
|
缓存 编译器 Linux
Linux内核开发流程指南 - 4. 编写正确的代码【ChatGPT】
Linux内核开发流程指南 - 4. 编写正确的代码【ChatGPT】
|
27天前
|
存储 Linux 网络安全
【Azure App Service】.NET代码实验App Service应用中获取TLS/SSL 证书 (App Service Linux/Linux Container)
【Azure App Service】.NET代码实验App Service应用中获取TLS/SSL 证书 (App Service Linux/Linux Container)
|
27天前
|
Linux Docker 容器
【Azure 应用服务】使用App Service for Linux/Container时,如果代码或Container启动耗时大于了230秒,默认会启动失败。
【Azure 应用服务】使用App Service for Linux/Container时,如果代码或Container启动耗时大于了230秒,默认会启动失败。
|
27天前
|
缓存 开发框架 NoSQL
【Azure Redis 缓存】VM 里的 Redis 能直接迁移到 Azure Cache for Redis ? 需要改动代码吗?
【Azure Redis 缓存】VM 里的 Redis 能直接迁移到 Azure Cache for Redis ? 需要改动代码吗?