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五种数据结构详解的更多相关文章

  1. redis 五种数据结构详解(string,list,set,zset,hash)

    redis 五种数据结构详解(string,list,set,zset,hash) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存 ...

  2. redis 五种数据结构详解(string,list,set,zset,hash),各种问题综合

    redis 五种数据结构详解(string,list,set,zset,hash) https://www.cnblogs.com/sdgf/p/6244937.html redis 与 spring ...

  3. 【Redis】redis 五种数据结构详解(string,list,set,zset,hash)

    redis 五种数据结构详解(string,list,set,zset,hash) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存 ...

  4. Redis 五种数据结构详解(string,hash,list,set,zset)

    一.五种数据结构: 1. String--字符串 String 数据结构是简单的 key-value 类型,value 不仅可以是 String,也可以是数字(当数字类型用 Long 可以表示的时候e ...

  5. 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. ...

  6. Redis(一)、Redis五种数据结构

    Redis五种数据结构如下: 对redis来说,所有的key(键)都是字符串. 1.String 字符串类型 是redis中最基本的数据类型,一个key对应一个value. String类型是二进制安 ...

  7. rabbitmq五种模式详解(含实现代码)

    一.五种模式详解 1.简单模式(Queue模式) 当生产端发送消息到交换机,交换机根据消息属性发送到队列,消费者监听绑定队列实现消息的接收和消费逻辑编写.简单模式下,强调的一个队列queue只被一个消 ...

  8. Redis五种数据结构(Windows Server)

    1.Redis的五种数据结构 这里推荐大家在命名redis的key的时候最好的加上前缀,并且使用 :来分割前缀 ,这里在使用可视化工具查看的时候就比较好区分,比如我的的前缀是 Demo:test:(一 ...

  9. Redis五种数据结构简介

    Redis五种结构 1.String 可以是字符串,整数或者浮点数,对整个字符串或者字符串中的一部分执行操作,对整个整数或者浮点执行自增(increment)或者自减(decrement)操作. 字符 ...

  10. Android特效 五种Toast详解

    Toast是Android中用来显示显示信息的一种机制,和Dialog不一样的是,Toast是没有焦点的,而且Toast显示的时间有限,过一定的时间就会自动消失.而且Toast主要用于向用户显示提示消 ...

随机推荐

  1. JDK 自带的服务发现框架 ServiceLoader 好用吗?

    请点赞关注,你的支持对我意义重大. Hi,我是小彭.本文已收录到 Github · AndroidFamily 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注公众号 [彭旭锐] ...

  2. 监控linux多个cpu的负载情况

    监控linux多个cpu的负载情况 top然后按数字键1

  3. 采云链SRM SaaS供应商管理系统,发展型中小企业的福音

    采购业务的发展遵循一些规律:采购从一开始围绕"供应商"开展,逐渐发展成围绕"货物"进行,如今围绕"供应商协同"和"采购流程管理&q ...

  4. PLM产品生命周期管理,包含哪些阶段?

    PLM:Product Lifecycle Management=产品生命周期管理.产品的整个生命周期包括:投入期.成长期.成熟期.衰退期.结束期.PLM系统使企业可以把多年积累的所有产品相关数据放到 ...

  5. Windows服务器限制进程CPU使用率

    在Windows server 2012 之前的服务系统 2008和2008 R2中有系统资源管理器System Resource Manager可以管理系统的CPU和内存使用情况.特别对于一些自己开 ...

  6. portainer 1.24.2 升级到 portainer-ce 最新版

    官方升级步骤文档: https://docs.portainer.io/v/ce-2.9/start/upgrade/docker 若是现在的版本是 portainer-ce 2.0.0 ,看Opti ...

  7. tar.gz方式安装nacos设置使用systemct进行service方式的管理并设置开机自启动--废弃不用这个

    nacos解压缩目录是:/opt/nacos 编写shell脚本 # vim /opt/nacos/bin/nacos.sh #!/bin/bash source /etc/profile workD ...

  8. 常见Content-Type(MIME)列表

    Content-Type(MIME)用于标识发送或接收数据的类型,浏览器根据该参数来决定数据的打开方式.多用于指定一些客户端自定义的文件,以及一些媒体文件的打开方式. 文件扩展名 Content-Ty ...

  9. 2022IDEA破解

    注意 本教程适用于 IntelliJ IDEA 2022.1.2 以下所有版本,请放心食用~ 本教程适用于 JetBrains 全系列产品,包括 IDEA.Pycharm.WebStorm.Phpst ...

  10. [题解] Atcoder ARC 142 E Pairing Wizards 最小割

    题目 建图很妙,不会. 考虑每一对要求合法的巫师(x,y),他们两个的\(a\)必须都大于\(min(b_x,b_y)\).所以在输入的时候,如果\(a_x\)或者\(a_y\)小于\(min(b_x ...