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是一种可以排序的集合。

相关文章
|
2月前
|
消息中间件 缓存 NoSQL
Redis各类数据结构详细介绍及其在Go语言Gin框架下实践应用
这只是利用Go语言和Gin框架与Redis交互最基础部分展示;根据具体业务需求可能需要更复杂查询、事务处理或订阅发布功能实现更多高级特性应用场景。
279 86
|
2月前
|
存储 消息中间件 NoSQL
Redis数据结构:别小看这5把“瑞士军刀”,用好了性能飙升!
Redis提供5种基础数据结构及多种高级结构,如String、Hash、List、Set、ZSet,底层通过SDS、跳表等实现高效操作。灵活运用可解决缓存、计数、消息队列、排行榜等问题,结合Bitmap、HyperLogLog、GEO更可应对签到、UV统计、地理位置等场景,是高性能应用的核心利器。
|
2月前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
116 12
|
2月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
1022 9
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
290 59
|
5月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
122 0
栈区的非法访问导致的死循环(x64)
232.用栈实现队列,225. 用队列实现栈
在232题中,通过两个栈(`stIn`和`stOut`)模拟队列的先入先出(FIFO)行为。`push`操作将元素压入`stIn`,`pop`和`peek`操作则通过将`stIn`的元素转移到`stOut`来实现队列的顺序访问。 225题则是利用单个队列(`que`)模拟栈的后入先出(LIFO)特性。通过多次调整队列头部元素的位置,确保弹出顺序符合栈的要求。`top`操作直接返回队列尾部元素,`empty`判断队列是否为空。 两题均仅使用基础数据结构操作,展示了栈与队列之间的转换逻辑。
|
10月前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
507 77
|
9月前
|
算法 调度 C++
STL——栈和队列和优先队列
通过以上对栈、队列和优先队列的详细解释和示例,希望能帮助读者更好地理解和应用这些重要的数据结构。
233 11