Redis -- 基础知识3 数据类型及指令

news2024/12/22 8:31:19

FLUSHALL:清空所有键值对操作(最好别搞,删库要被绳之以法的)

1.string类型

1.介绍

1.redis的字符串,直接按照二进制进行存储,所以可以存储任何数据,取出时不需要转码

2.redis的string类型,限制大小最大为512M,因为为单线程模型为了操作短平快

2.操作

1.set与get

set key value [ex seconds | px iseconds] [NX | XX]:添加string类型的键值对

1.一个语句可追加多条操作,而且合并的操作是原子性的

2.NX:如果key存在,则不设置,不存在则设置 ; XX:key存在更新设置,不存在不设置

3.如果key存在,则覆盖value,并且ttl也会失效

get key:获取key,只支持string类型的操作,如果不是会报错

2.mset与mget

操作多组键值对,减少了网络传输次数,增加效率

mset key value [key value...]:多次添加,但不是不要加太多,会使得redis阻塞

mget key [key]:一次性查找多次

3.setnx/setex/psetex

setnx: set同时设置nx选项,如果key存在,则不设置,不存在则设置

setex: 添加键值对并且设置超时时间

psetex:添加键值对并且设置毫秒级超时时间

4.incr/incrby/decr/decrby/incrbyfloat

value类型为int类型才能操作,并且数不能超过范围.操作的时间复杂度都是O(1),多客户端一起发送也不会出现线程安全问题

incr key: value+1 (64位),如果key不存在,当作当作value为0的键值对

incrby key n: value+n,n为正负数都可以

decr key: value-1

decrby key n: value-n,n为正负数都可以

incrbyfloat key n: value +/- 小数

5.append/getrange/setrange/strlen

append key value: 追加字符串,如果key没有则功能等于set.返回值的长度是字节

编码字节大小由shell设置,utf-8的汉字字节为3字节.get汉字不会返回汉字,会返回编码.需要在启动客户端时加上 --raw 的选项,客户端就会尝试翻译

getrange key start end: 获取字符串的一部分,区间范围为[start,end].负数表示倒数第几个.切分汉字可能会出现问题

setrange key offset value: 将offset位置的数据开始替换成value.替换结束返回新字符串的长度.如果当前替换的是汉字,那么可能会出现问题

strlen key:获取到字符串的长度,单位为字节

3.string编码方式

int: 8字节的长整型

embstr: 小于等于39字节的字符串

raw: 大于39字节的字符串

小数存储为一个字符串,而不是int类型.所以进行加减运行会进行转换

4.应用场景

1.作为缓存

应用服务器访问数据时,先查redis中是否存在,如果有直接返回给服务器;如果没有则在MySQL中寻找,并且将数据存一份到redis中.其功能就是把缓存用于存储热点数据,不过热点数据选择的策略是人为定义的.随时间推移key会越来越多,那么我们需要可以设置超时时间.当然redis在内存不足时,提供了淘汰机制.

2.计数

例如统计视频的观看次数.如果统计TopK的数据不太可以,使用MySQL更好

3.共享会话(session)

每一个服务器都在redis中维护同一份session,只要每个请求过来,每一个服务器都能对该请求进行处理与响应

2.hash类型

key field value形式,key对应一整个hash表

1.命令

1.hset/hget/hexists

hset key field value [field value...]:针对key跟上若干field与value的键值对.返回值为键值对的个数,value的类型为字符串

hget key field: key找到hash表,通过field找到value

hexists key field: 判断hash表中是否存在field

2.hdel

hdel key field[key field...]: 删除的是field,而不是key.返回删除的字段个数

3.hkeys/hvals

hkeys key: 查看所有field字段.找到hash,遍历hash的所有field.该操作有一定风险,与keys *差不多的错误

hvals key: 获取key中的所有value

4.hgetall/hmget

hgetall key: 查看所有field和对应的value,不推荐使用

hmget key field [field...]: 查看指定多个field的value

hscan key:渐进式遍历.敲一次遍历一部分

5.hlen/hsetnx/hincrby/hincrbyfloat

hlen key: hash的filed-value键值对个数,时间复杂度为O(1)

hsetnx key field value: 不存在则设置,存在则失败

hincrby key field n: hash的value也可当成整数,加减正负都行

hincrbyfloat key field n: hash的value也可当成浮点数,加减正负都行

2.hash编码方式

ziplist:压缩链表,适用于元素个数少,每个value的长度比较短

hashtable:hash表

3.应用

作为缓存:存储结构化的数据,类似于数据库的表结构.

1.hash类型是稀疏的,而关系型数据库是完全结构化的

2.关系型数据库可做复杂性查询,而redis不可以

3.list类型

类似于双端队列(deque),链表中的元素允许重复,下标从0开始

1.命令

1.lpush/lrange/lpushx/rpush

lpush key value [value...] :头插,返回值为list的长度

lrange key start end :查看[start,end]的区间,越界会返回能得到的所有数据

lpushx key value [value...] :key存在才头插

rpush key value [value...] :尾插,返回值为list的长度

2.lpop/rpop

lpop key :头删,返回删除元素值,或者返回空

rpop key :尾删,返回删除元素值,或者返回空

3.lindex/linsert/llen

lindex key index:给定下标,返回对应元素,时间复杂度为O(N)

linsert key <befor | after> pivot value :按顺序找pivot基准值,在其前面或者后面插入value元素,返回元素个数,时间复杂度为O(N)

llen key :获取list的元素个数

4.lrem

lrem key count element :count>0,删除element开始从左往右删除count次 ; count<0,删除element开始从右往左删除count次 ; count=0,删除所有的element

5.ltrim/lset

ltrim key start stop: 保留[start,stop]间元素

lset key index element: 修改任何位置的元素

6.阻塞式命令

阻塞:一旦list数据为空就会阻塞

blpop和brpop如果在list数据为空就会产生阻塞,直到list中有数据为止,当然可以设置阻塞时间,一旦超时就不再等待.返回一个二元组,哪个key取出哪个数据

blpop key [key...] timeout :一旦多个key存在一个数据,那么就会执行

brpop key [key...] timeout

2.list编码方式

ziplist: 压缩链表,节省空间,适用于元素个数少

linkedlist: 真实链表,适用于元素个数多

quicklist: redis5之后使用现在的结构,结合了ziplistlinkedlist,整体是链表,但是每一个元素是压缩链表

3.应用场景

1.list作为数组,存储多个元素

2.消息队列(生产者消费者模型),轮询模型

4.set类型

1.命令

1.sadd/smembers

sadd key member [member...]: 添加set的元素,返回添加成功的元素

smembers key :key中所有的元素

sismember key member :测试某一个member是否存在

2.spop/srandmember

spop key count: 随机删除count个元素

srandmember key count:随机获得count个元素

在源码中,针对spop与srandmember就采取了生成随机数的操作

3.smove/srem

smove key1 key2 member:从key1中删除member再加到key2中

srem key member [member...]: 删除指定元素,返回删除的个数

4.集合间操作

1.交集:

sinter key [key..]: 获取交集,时间复杂度为O(n*m)

sinterstore des key [key..]: 算好交集存到des中

2.并集:

sunion: 求并集,时间复杂度为O(n)

sunionstore des key [key..]: 求并集存到des中

3.差集:

sdiff key [key...]: 第一个key为参考,时间复杂度为O(n)

sdiffstore des key [key..]: 求差集存到des中

2.set编码方式

intset:整数集合,节省空间的特定优化,元素均为整数,元素个数不多的情况下使用

hashtable:哈希表

3.应用场景

1.保存特征形成标签,并且方便计算交集,找到两个集合的公共标签

2.使用set计算用户之间的共同好友

3.使用set统计UV,去重.(pv:page view用户每次访问都会产生一个pv;uv:user view一个用户产生一个uv)

5.zset

1.命令

1.zadd

zadd key [NX | XX] [GT | LT] [CH] [INCR] score member [score member...]: key中添加一个含score的member,返回值为新增的元素个数(不显示修改).时间复杂度为O(logN),主要因为跳表.修改后顺序会自动变换

不加[NX | XX]:不存在member就添加新的member,存在就更新member

NX:存在时不设置,没有member更新member

XC:更新存在的member

LT:只更新存在的元素,更新元素比要被更新的小才更新

GT:只更新存在的元素,更新元素比要被更新的大才更新

CH:返回值进行描述,原本返回添加的元素个数,加入CH则也会返回被修改的元素个数

INCR:对现有member能加减操作

特别的:score可以为浮点数,zset的排序默认为升序方式排列

2.zcard/zcount

zcard key:获取元素个数(member数量).时间复杂度为O(1)

zcount key min max: score在max和min之间的member个数,(max (min这样写不包含两端.时间复杂度为O(logN).max和min可以是浮点数,可以使用inf正无穷大和-inf负无穷大

3.zrange/zrevrange/zrangebyscore

zrange key start end [withscores]:查看[start,end]下标之间的元素,withscores现实members的score.时间复杂度为O(log(N)+M),升序查询

zrevrange key start end [withscores]:降序查询

zrangebyscore key min max [withscores] :查询分数范围内的元素

4.zpopmax

zpopmax key [count] :删掉count个最大的score对应的元素.如果元素的score相同,那么此时删除按照member的大小顺序进行一个一个删除.

删除的是最大的数据,那么其实等于是尾删.其时间复杂度为O(logN)

5.bzpopmax/bzpopmin

bzpopmax key [key...] timeout :删除最大的数一次,zset为空时阻塞,阻塞超时时间为timeout,并且单位为秒,支持小数

bzpopmin key [key...] timeout:删除最小的数一次,zset为空时阻塞,阻塞超时时间为timeout,并且单位为秒,支持小数

时间复杂度都是O(logN),key有很多也是一次

6.zrank/zrevrank/zscore

zrank key member: 查看member对应的下标,member不存在返回空.以升序的顺序算的

zrevrank key member:以逆序的顺序算的

zscore key member:查询指定member的score,时间复杂度为O(1) - 查询优化了

7.zrem/zremrangebyrank/zremrangebyscore

zrem key member [member...]: 删除member元素,返回删除元素个数.时间复杂度为O(logN*M)

zremrangebyrank key start end:下标描述范围进行删除元素.时间复杂度为O(logN+M)

zremrangebyscore key start end:分数描述区间进行删除元素.时间复杂度为O(logN+M)

8.zincrby

zincrby key increment member:对member的score增加increment

9.有序集合间关系操作

zinter交集,zunion并集,zdiff差集 -- redis6.2之后支持的

zinterstore des numkeys key [key...] [WEIGHT weight [weight...]] [AGGREGATE <SUM | MIN | MAX>]:交集,存在指定key中

zunionstore des numkeys key [key...] [WEIGHT weight [weight...]] [AGGREGATE <SUM | MIN | MAX>]:并集,存在指定key中

numkeys:多少个key进行交集运算.之所以需要显示,是因为若干个keys之后还有可有可无的操作,需要进行区分

WEIGHT:乘以权重,操作的优先级标准.即对member求交集同时要计算score权重的占比.要算权重那WEIGHT必须写

AGGREGATE:总数合计.SUM为score的总和,MIN为score最小值,MAX为score的最大值

zinterstore的时间复杂度为O(N*K)+O(M*logM),N为最小zset个数,K为numkey,M最终个数.约等于O(M*logM)

zunionstor的时间复杂度为O(N)+O(M*logM),N为所有zset个数

2.zset的编码方式

1.ziplist:适用于元素个数少,单个元素体积小.节省内存空间

2.skiplist:适用于元素个数多,单个元素体积大.查询的时间复杂度为O(logN)

3.应用场景

关键场景:实时的排行榜,可以高效更新

游戏排行看分数,单一的

其他综合热度,需要进行权重计算

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1139533.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

财务数字化转型是什么?_光点科技

财务数字化转型是当今企业发展中的一项关键策略&#xff0c;旨在借助先进的数字技术&#xff0c;重新塑造和优化财务管理体系&#xff0c;以适应迅速变化的商业环境。这一转型不仅仅是技术的升级&#xff0c;更是对企业财务理念和流程的全面升级和改革。 财务数字化转型的核心在…

【Java】Java开发环境搭建

Java开发环境搭建 文章目录 Java开发环境搭建1. Java开发环境搭建1.1 什么是JDK、JRE1.2 JDK的下载1.3 JDK的安装1.4 配置path环境变量1.4.1 理解path环境变量1.4.2 JDK8配置&#xff1a;配置JAVA_HOMEpath1.4.3 JDK17配置方案&#xff1a;自动配置 1. Java开发环境搭建 1.1 什…

掌握CSS Flexbox,打造完美响应式布局,适配各种设备!

&#x1f3ac; 江城开朗的豌豆&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 &#x1f4dd; 个人网站 :《 江城开朗的豌豆&#x1fadb; 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! ​ 目录 ⭐ 专栏简介 &#x1f4d8; 文章引言 基…

磁盘监控:告警时发送邮件

1.配置邮箱 1.编辑邮箱配置文件 vim /etc/mail.rc2.在末尾输入自己的邮箱配置&#xff0c;以163邮箱为例 #开启ssl set ssl-verifyignore #证书目录&#xff0c;下方为centos系统证书默认位置&#xff0c;也自行生成证书并指定 set nss-config-dir/etc/pki/nssdb # 配置的第…

Windows 11 如何同步文件到OneDrive ?

Windows 11 中的 OneDrive OneDrive 默认内置于 Windows 11系统中。Windows 11从设置中删除了原来的两种备份方法并添加了OneDrive。更重要的是&#xff0c;微软在设置中添加了OneDrive Sync&#xff0c;以取代设置中的备份功能。 您可以使用 OneDrive 在计算机和云之间同步文…

【Leetcode】200. 岛屿数量

给你一个由 1&#xff08;陆地&#xff09;和 0&#xff08;水&#xff09;组成的的二维网格&#xff0c;请你计算网格中岛屿的数量。 岛屿总是被水包围&#xff0c;并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。 此外&#xff0c;你可以假设该网格的四条边…

【信创】 银河麒麟 软件目录及 常见问题汇总(持续更新)

1. 官方问题列举常见问题 常见问题国产操作系统、银河麒麟、中标麒麟、开放麒麟、星光麒麟——麒麟软件官方网站 2. 官方资源池目录 Index of /kylin/KYLIN-ALL/pool/ 如 gcc 的安装依赖 deb包目录&#xff1a; 3. 麒麟系统各版本 软件源使用方法

70 搜索插入位置

搜索插入位置 题解1 二分查找防越界写法 题解2 STL大法两行 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c; 并返回其索引。如果目标值不存在于数组中&#xff0c; 返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O ( l o g n ) O(log n…

学习paddle-detection(paddlex的使用)

首先下载paddlex&#xff08;网页&#xff09;的本地软件&#xff0c;下载链接如下&#xff1a; paddlex 下载完成后进行安装 打开后选择开发者模式&#xff0c;开发者模式主要是和VScode进行集成 本章节主要介绍在开发者模式下可以查看和编辑的文件及其作用&#xff0c;关于…

Vuex插件的安装与使用原理

Vuex插件的安装与使用原理 Vuex安装和环境搭建 安装Vuex 第一步&#xff1a;打开CMD窗口&#xff0c;通过命令转到Vue的安装路径第二步&#xff1a;输入安装Vuex的命令 vue2 安装 Vuex3 版本&#xff1a;npm i vuex3vue3 安装 Vuex4 版本&#xff1a;npm i vuex4 当在CMD窗口…

pycharm运行R语言脚本(环境安装)

文章目录 简介1. pycharm安装插件2. 安装R语言解释器2.1下载安装包2.2具体安装过程 3.编辑环境变量4.pycharm中配置安装好的R语言解释器 简介 pycharm 安装 R language for Intellij R language for Intellij 是一个插件&#xff0c;它为Intellij IDEA集成开发环境添加了对R语…

Bootstrap 中CSS媒体查询分辨率 @media(min-width)

媒体查询是非常别致的"有条件的 CSS 规则"。它只适用于一些基于某些规定条件的 CSS。如果满足那些条件&#xff0c;则应用相应的样式。 Bootstrap 中的媒体查询允许您基于视口大小移动、显示并隐藏内容。下面的媒体查询在 LESS 文件中使用&#xff0c;用来创建 Boot…

Chat2DB下载、以及AI功能使用

&#x1f4d6; 简介 Chat2DB 是一款有开源免费的多数据库客户端工具&#xff0c;支持 windows、mac 本地安装&#xff0c;也支持服务器端部署&#xff0c;web 网页访问。和传统的数据库客户端软件 Navicat、DBeaver 相比 Chat2DB 集成了 AIGC 的能力&#xff0c;能够将自然语言…

在线客服系统源码H5网页版 带完整搭建教程

今天源码小编来给大家介绍一个新源码系统在线客服系统源码H5网页版。与传统客服系统相比&#xff0c;在线客服系统源码H5网页版具有更高的灵活性和可扩展性&#xff0c;同时能够更好地支持移动端访问。 H5网页版在线客服系统源码采用前端与后端分离的技术架构&#xff0c;前端…

Redis文件事件模型

Redis是事件驱动的程序&#xff0c;并基于Reactor模式开发了自己的网络事件处理器&#xff0c;被称之为文件处理器(File Event Handler)。 文件处理器通过I/O多路复用程序来同时监听多个Socket&#xff0c;并根据Socket目前执行的任务来关联不同的事件处理器。当被监听的Socket…

一次js请求一般情况下有哪些地方会有缓存处理

目录 前言 1. 浏览器缓存 1.1 强缓存 用法 代码 理解 1.2 协商缓存 用法 代码 理解 2. 服务端缓存 2.1 反向代理缓存 用法 代码 理解 2.2 应用层缓存 用法 代码 理解 3. CDN缓存 3.1 用法 3.2 理解 4. DNS缓存 4.1 用法 4.2 理解 5. AJAX请求缓存 5.…

大数据平台架构及规划

梳理了数据平台及未来规划&#xff0c;具体如下&#xff1a; 整体架构&#xff1a; 当前建设进展&#xff1a; 部署架构 部署架构2&#xff1a; Flink 实时计算平台架构 版本1&#xff1a; 版本2&#xff1a; 离线平台架构&#xff1a; 未来规划&#xff1a;

爱玛电动车:不止有时尚设计,更有领先的引擎动力科技

从外卖骑手的穿梭配送,到上班族的日常通勤;从年轻女孩的时尚出街,到为人父母的带娃出行。经过二十多年的高速发展和监管探索,电动两轮车已成为我国居民短途出行的重要民生交通工具和生产力工具,而消费者对电动车产品科技水准和质量的需求,也在不断提高。 未来,电动两轮车行业将…

记一次EasyExcel导出时将空格丢失的问题

EasyExcel的issues可以看到 需求&#xff1a;导出的数据以树形展示&#xff0c;如下&#xff1a; 导出结果&#xff1a; 原因&#xff1a; EasyExcel会默认去除掉空格&#xff0c;autoTrim熟悉默认为true&#xff0c;只需要设置为false即可。

学生用台灯应该选什么样的?分享好用的学生台灯

很多导致在那个不注重孩子学习的光线问题&#xff0c;导致孩子在不知不觉中视力下降。要知道&#xff0c;孩子在阅读书本、书写作业时&#xff0c;注意力都是高度集中的&#xff0c;如果孩子是在昏暗的光线下用眼&#xff0c;会造成瞳孔长时间散大&#xff0c;出现眼内液体循环…