redis五种数据结构详解
5.相关介绍和命令
5. redis是单线程+多路io复用技术
多路复用是指使用一个线程来检查多个文件描述符的就绪状态,比如调用select和poll函数,传入多个文件毛舒服,如果有一个文件描述符就绪,则返回,否则阻塞到超时。得到就绪状态后进行真正的操作可以在用一个线程里执行,也可以启动线程执行(比如使用线程池)
串行 vs 多线程+锁 vs 单线程+多路io复用(redis)
5.2 redis 健(key)
keys * 才看看当前库所有的key
exists key的名称 1表示在 0表示不存在
type key key的类型
del key 删除 key
expeire key 设置过期时间
ttl key 查看还有多久过期 -1 永不过期 -2过期
select 数字 表示切换库 select 1 切换到1号库
dbsize 查看当前数据库的key的数量
flushdb 清空当前库
flushall 清空所有库
5.2常用数据类型操作 string
string字符串是redis的最基本的啥类型,一个key对应一个value ,string类型是二进制安全的,意味着redis的string可以包含任何数据,比如jpg 图片或者序列化对象
基本命令:
set命令:
set k1 v100 为k1设置值为v100
get k1 查询k1的值
append k1 abc k1的值为v100abc
strlen 获取值的长途
setnx 只有在key不存在的时候,才能成功 setnx k1 v1 返回 0 为不成功 为1 表示成功
incr 将key中存储的数字值增1
decr 将key中存储的数字值减1
** 注意redis中是原子操作:因为redis是单线程+多路io复用**
5.3思考 java中的 i++是否为原子操作
下一波命令:
mset:设置多个key value
mget:设置多个value
msetnx: 任何一个存在,则所有都失败
getrange:获取指定大小的范围的值
setrange 在指定的范围设置值
5.3redis列表
单键多值
redis列表是简单的字符串列表,按照插入顺序飘絮。你可以添加一个元素到列表的头部(左边)或者尾部(右边),它的底层为一个双向列表,
常用命令:
lpush:左边添加value值
rpush: 右边添加value值
lrange: 从左边开始取(到范围为止)
lpop/rpop 从左/右吐出一个值。值在健在,值光健亡
lrange 获取指定范围的值
lindex 按照索引下表获取元素
llen 获取列表长度
linsert before 在的后面插入插入值
lset 将列表key下表为index的值替换为value
5.4 集合 set
set和list差不多,主要是会自动排重,而且数无序的。redis的set是string类型的无序集合,他底层其实是一个value为null的hash表,所以添加、删除、查找的复杂度都是0(1)。
常用命令:
sadd:将一个或多个元素加入到集合可以在指那个,已经存在的member元素将被忽略
smembers:取出所以集合的值
sismember:是否含有该值
scard:返回该集合的元素个数
srem 删除集合中的某个元素
spop:随机从该集合吐出一个值
srandmember:随机从该集合中取出n个值,不会从改集合中删除。
smove:把集合中的某一个值从一个集合移动到另一个集合
**sinter 返回两个集合的交集元素
**sunion;返回两个集合的并集元素 共同好友功能
**sdiff:返回两个集合的差集元素
5.4redis-hash类型
redis hash 是一种键值对的类型
redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。,类似于java中的Map<String,Object>
命令:
hset 给集合中的键赋值
hget 获取某个filed的值
hmset 批量设置多个filed值
hexists:判断是否存在这个字
hkeys:查询所有的filed值
hvals:查询所有的value
hincrby:加一
hsexnx 加数据的
5.5 zset数据结构
redis 有序集合zset与普通的集合set非相似,是一个没有重复的有序集合
底层结构:
命令:
zset的两种实现方式
ziplist(压缩链表):满足以下两个条件的时候
元素数量少于128的时候
每个元素的长度小于64字节
skiplist(跳跃链表):不满足上述两个条件就会使用跳表,具体来说是组合了map和skiplist
map用来存储member到score的映射,这样就可以在O(1)时间内找到member对应的分数
skiplist按从小到大的顺序存储分数
skiplist每个元素的值都是[score,value]对
zdd:添加内容(一个或者多个)
zrange:返回有序集key中,下标在之间的元素
zrangbyscore :取指定区域的方法
zrevrangbyscore:与上述的排序方式相反
zincrby: 为score值进行增加操作
zrem:删除某个 指定的元素
zcount:统计功能
redis五种数据结构详解的更多相关文章
- redis 五种数据结构详解(string,list,set,zset,hash)
redis 五种数据结构详解(string,list,set,zset,hash) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存 ...
- redis 五种数据结构详解(string,list,set,zset,hash),各种问题综合
redis 五种数据结构详解(string,list,set,zset,hash) https://www.cnblogs.com/sdgf/p/6244937.html redis 与 spring ...
- 【Redis】redis 五种数据结构详解(string,list,set,zset,hash)
redis 五种数据结构详解(string,list,set,zset,hash) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存 ...
- Redis 五种数据结构详解(string,hash,list,set,zset)
一.五种数据结构: 1. String--字符串 String 数据结构是简单的 key-value 类型,value 不仅可以是 String,也可以是数字(当数字类型用 Long 可以表示的时候e ...
- 2.Redis五种数据结构
2.Redis五种数据结构2.1 预备2.1.1 全局命令2.1.2 数据结构和内部编码2.1.3 单线程架构2.2 字符串2.2.1 命令2.2.2 内部编码2.2.3 典型使用场景2.3 哈希2. ...
- Redis(一)、Redis五种数据结构
Redis五种数据结构如下: 对redis来说,所有的key(键)都是字符串. 1.String 字符串类型 是redis中最基本的数据类型,一个key对应一个value. String类型是二进制安 ...
- rabbitmq五种模式详解(含实现代码)
一.五种模式详解 1.简单模式(Queue模式) 当生产端发送消息到交换机,交换机根据消息属性发送到队列,消费者监听绑定队列实现消息的接收和消费逻辑编写.简单模式下,强调的一个队列queue只被一个消 ...
- Redis五种数据结构(Windows Server)
1.Redis的五种数据结构 这里推荐大家在命名redis的key的时候最好的加上前缀,并且使用 :来分割前缀 ,这里在使用可视化工具查看的时候就比较好区分,比如我的的前缀是 Demo:test:(一 ...
- Redis五种数据结构简介
Redis五种结构 1.String 可以是字符串,整数或者浮点数,对整个字符串或者字符串中的一部分执行操作,对整个整数或者浮点执行自增(increment)或者自减(decrement)操作. 字符 ...
- Android特效 五种Toast详解
Toast是Android中用来显示显示信息的一种机制,和Dialog不一样的是,Toast是没有焦点的,而且Toast显示的时间有限,过一定的时间就会自动消失.而且Toast主要用于向用户显示提示消 ...
随机推荐
- JDK 自带的服务发现框架 ServiceLoader 好用吗?
请点赞关注,你的支持对我意义重大. Hi,我是小彭.本文已收录到 Github · AndroidFamily 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注公众号 [彭旭锐] ...
- 监控linux多个cpu的负载情况
监控linux多个cpu的负载情况 top然后按数字键1
- 采云链SRM SaaS供应商管理系统,发展型中小企业的福音
采购业务的发展遵循一些规律:采购从一开始围绕"供应商"开展,逐渐发展成围绕"货物"进行,如今围绕"供应商协同"和"采购流程管理&q ...
- PLM产品生命周期管理,包含哪些阶段?
PLM:Product Lifecycle Management=产品生命周期管理.产品的整个生命周期包括:投入期.成长期.成熟期.衰退期.结束期.PLM系统使企业可以把多年积累的所有产品相关数据放到 ...
- Windows服务器限制进程CPU使用率
在Windows server 2012 之前的服务系统 2008和2008 R2中有系统资源管理器System Resource Manager可以管理系统的CPU和内存使用情况.特别对于一些自己开 ...
- portainer 1.24.2 升级到 portainer-ce 最新版
官方升级步骤文档: https://docs.portainer.io/v/ce-2.9/start/upgrade/docker 若是现在的版本是 portainer-ce 2.0.0 ,看Opti ...
- tar.gz方式安装nacos设置使用systemct进行service方式的管理并设置开机自启动--废弃不用这个
nacos解压缩目录是:/opt/nacos 编写shell脚本 # vim /opt/nacos/bin/nacos.sh #!/bin/bash source /etc/profile workD ...
- 常见Content-Type(MIME)列表
Content-Type(MIME)用于标识发送或接收数据的类型,浏览器根据该参数来决定数据的打开方式.多用于指定一些客户端自定义的文件,以及一些媒体文件的打开方式. 文件扩展名 Content-Ty ...
- 2022IDEA破解
注意 本教程适用于 IntelliJ IDEA 2022.1.2 以下所有版本,请放心食用~ 本教程适用于 JetBrains 全系列产品,包括 IDEA.Pycharm.WebStorm.Phpst ...
- [题解] Atcoder ARC 142 E Pairing Wizards 最小割
题目 建图很妙,不会. 考虑每一对要求合法的巫师(x,y),他们两个的\(a\)必须都大于\(min(b_x,b_y)\).所以在输入的时候,如果\(a_x\)或者\(a_y\)小于\(min(b_x ...