Redis基础篇:Redis常见命令与数据结构

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis基础篇:Redis常见命令与数据结构


第一章:Redis数据结构介绍

Redis是一个key-value的数据库,key一般是String类型,不过value是多种多样的。

一:五种常见基本类型

String:代表他的值就是一个普通的字符串。

Hash:值是一个哈希表。

List:本质上是一个链表

Set:本质上是一个无须集合,并且不能重复

SortSet:有序的,不能重复的集合。

二:三种不常见类型

GEO:地理坐标

BitMap:按位存储的一种方式,底层的本质就是字符串。

HyperLog:按位存储的一种方式,底层的本质就是字符串。

下边这三种就是将上边的基本类型做了一些特殊的处理,我们称呼为特殊类型。

Redis当中除了八中类型之外, 还有其他的类型,包括消息队列等等其他的类型。

第二章:数据类型的使用

Redis方便我们学习,将操作不同的数据类型做了分组,对于不同的数据类型会有不同的命令。

https://redis.io/commands这里边可以查看不同的命令。Redis当中的命令都是分组的,我们基于不同的分组来查看对应命令。我们进入redis-cli之后,我们可以使用help @generic查看redis所有的命令。使用help @String查看String数据类型下面的命令,使用help @sort_set查看set类型下面的命令…

一:Redis通用命令

Redis通用命令是对所有的数据结构都生效的,help @generic来查看即可。

keys:查看符合模板的所有的key,keys * 返回所有的键,keys a* 返回所有a开头的键…

模糊搜索效率往往不高,占用很长的时间片。redis核心执行都是单线程的,所以这个时候其他命令都阻塞着导致无法执行。生产中尽量不要执行这样的命令。

del:作用删除一个执行的key,del name,返回值是一个Integer 1,del k1 k2 k3 k4 批量删除,Integer 3的话代表只删除了三个,有的key可能压根不存在。

exists:判断是否存在。exists name 返回 integer 1代表存在。integer 0代表不存在。

expire:给一个key设置一个有效期,有效期到期该key会被自动删除。为了节约内存。expire age 20

单位默认是秒,我们设置一个key值得时候,我们不设置有效期它的ttl key的值是-1,这样的话代表是永久有效。

ttl:查看一个key的剩余有效期。TTL age 当返回的结果是 integer -2的时候代表这个key已经被移除了。

二:String类型

String类型也就是字符串类型,是Redis当中的最简单的存储对象。value指的就是字符串,根绝字符串的格式不同,又可以分为三类:

不管是那种格式的字符串,底层肯定是字节数组的形式去存储,只不过编码的方式不同。字符串类型的最大空间不能超过512MB。

String:普通字符串,

int:整数类型,可以做自增自减操作。

float:浮点类型,可以做自增自减操作。

底层是把数组直接转成二进制形式进行存储,一个字节就能表示大数据,且可以直接进行加减操作。字符串的话,把字符转成对应的字节码,相对来讲,占用的空间比较大一点。

1:String常见命令

2:String常见命令实操

set name wangwu nx 效果等价与 setnx name wangwu

setex name 10 jack 效果等价与 set name jack ex 10

三:key的层级格式

Redis是键值型的数据库,这种情况下就要求我们的key是唯一的。

Redis允许多个单词形成层级结构,多个单词之间使用:隔开,或者使用_隔开即可。

Java对象不是字符串,我们完全可以将对象序列化为JSON字符串后进行存储。

我们可以看到,可视化客户端自动就把我们的key,层级化展示了:

四:Hash类型

Hash类型,也叫作散列,其Value是一个无序字典,类似于Java中的HashMap结构。

Value是一种类似于HashMap的这样的数据结构。

1:Hash常见命令

2:Hash常见命令使用

五:List类型

1:List常见命令

1):特征

Redis的List类型与Java中的LinkedList类似,可以看做是一个双向链表结构。既可以支持正向检索也可以支持反向检索(双向链表的最大的特点)。

特征也是与LinkedList极为相似的:

有序性:与插入顺序是一致的。

元素可以重复:不会检查元素的重复性。

插入和删除很快:所有的链表插入和删除很快,因为查询和删除只是改变了链表中指针的指向。

查询的速度一般:逐个节点遍历去使用。

2):使用场景

点赞,需要看到点赞的先后顺序,评论,需要知道评论的先后顺序。

L:队首,R:队尾

BLPOP阻塞命令。

2:List常见命令使用

思考:如何使用List结构模拟一个栈、模拟一个队列、阻塞队列。

栈:先进后出,后进先出,出口和入口在同一边。

队列:入口和不在同一边。

阻塞队列:入口和出口不在同一边,出队列时采用BLPOP或者BRPOP。

六:Set类型

Redis的Set结构与Java中的HashSet相似。可以看做事value为null的HashMap。因为也是一个hash表,一次具备与HashSet类似的特征。

无序:数据的存储顺序与我们的插入顺序是无关的。

元素不可重复:相同元素会进行覆盖

查找快:hash表查找是比较快的。

支持交集、并集、差集等功能:共同好友、好友列表、关注列表。

最后三个是多个集合之间的操作。

七:SortedSet类型

可排序的Set集合,Java中的TreeSet是一种可以排序的集合。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
7天前
|
存储 监控 NoSQL
Redis处理大量数据主要依赖于其内存存储结构、高效的数据结构和算法,以及一系列的优化策略
【5月更文挑战第15天】Redis处理大量数据依赖内存存储、高效数据结构和优化策略。选择合适的数据结构、利用批量操作减少网络开销、控制批量大小、使用Redis Cluster进行分布式存储、优化内存使用及监控调优是关键。通过这些方法,Redis能有效处理大量数据并保持高性能。
28 0
|
6天前
|
NoSQL API Redis
Redis源码(1)基本数据结构(上)
Redis源码(1)基本数据结构
22 2
|
6天前
|
NoSQL Redis 数据库
Redis中的常用命令非常丰富,涵盖了各种数据类型的基本操作以及服务器管理和维护的相关指令
【5月更文挑战第15天】Redis常用命令包括通用(如PING、SELECT)、键操作(KEYS、EXISTS、DEL)、字符串(SET、GET)、哈希(HSET、HGET)、列表(LPUSH、LPOP)、集合(SADD、SMEMBERS)和有序集合(ZADD、ZRANGE)等。这些命令用于数据操作及服务器管理,满足不同场景需求。了解更多命令,建议参考Redis官方文档。
17 2
|
6天前
|
存储 NoSQL 算法
Redis源码、面试指南(2)内存编码数据结构(下)
Redis源码、面试指南(2)内存编码数据结构
20 4
|
6天前
|
存储 NoSQL API
Redis源码、面试指南(2)内存编码数据结构(上)
Redis源码、面试指南(2)内存编码数据结构
17 0
|
7天前
|
存储 缓存 NoSQL
Redis源码(1)基本数据结构(下)
Redis源码(1)基本数据结构
11 1
|
7天前
|
NoSQL 安全 算法
Redis源码(1)基本数据结构(中)
Redis源码(1)基本数据结构
27 5
|
NoSQL 测试技术 Redis
Redis命令性能优化及事务使用过程(下)
Redis命令性能优化及事务使用过程(下)
503 0
Redis命令性能优化及事务使用过程(下)
|
存储 移动开发 NoSQL
Redis命令性能优化及事务使用过程(上)
Redis命令性能优化及事务使用过程(上)
191 0
Redis命令性能优化及事务使用过程(上)
|
NoSQL Redis C++
Redis命令——事务
Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证: 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。
979 0