【redis学习篇1】redis基本常用命令

目录

redis存储数据的模式

常用基本命令

一、set

二、keys pattern

keys +字符串当中携带问号

keys +字符串当中携带*号

keys + 【^+字母】

keys +*

三、exists

四、del

五、expire

5.1 ttl命令

5.2key删除策略

5.2.1惰性删除

5.2.2定期删除

六、type

key的数据类型

string

incr:自增1,仅限数字类型

incrby key +一个具体的数量

decr key

incrbyfloat key +一个值

append

getrange key +start +end

setrange key start+替换的字符串

strlen key

hash

hset key file1 value1

hget key file1

hexists key file1

hdel key file1

hkeys key

list

lpush

lrange

rpush 

lpop

lindex 

llen key

set

Set的常见操作

SADD命令

SMEMBERS 命令

SISMEMBER 命令

SPOP命令

SRANDMEMBER命令

SMOVE 命令

SREM 命令

zset

一、zset数据类型概述

二、zset的常见操作


redis存储数据的模式

一般情况下,都是以 key value的模式进行存储的。

这种存储的结构类似于哈希表(HashMap);

但是redis不同于哈希表的地方在于:

redis的key只可以是string类型;value可以是其他数据结构。

而HashMap的key和value都可以是任意的数据结构。

对于value的类型,有字符串哈希表列表集合有序集合等数据结构的类型

而操作这些不同的数据结构,就会用到不同的命令。


常用基本命令

一、set

用法:set 【key】 【value】

在这里面,key和value都是字符串;由用户手动输入key和value的值;

当敲回车之后提示OK说明已经设置成功了; 


二、keys pattern

pattern为包含特殊符号的字符串;

keys +字符串当中携带问号

例如:keys h?llo

?只能匹配一个字符;因此返回的字符可能是:hello/hallo等;就是问好只能占据一个字符;


keys +字符串当中携带*号

例如:当输入:keys h*llo的时候

返回的内容可能是:heeeeello;habcdllo也是就*可以代替若干个字母


keys + 【^+字母】

这种情况,是为了排除某个字母设置的。


keys +*

查询当前服务器上面的所有key


三、exists

判定key是否存在

用法:exists +key的名称:返回key存在的个数

假如一个key hello存在,那么 exists + hello就会返回1.

假如一个key hello,hallo存在;那么 exists +hello+hallo 就会返回2.


四、del

删除某个key.

del +key的名称:删除某一个key;删除成功返回1;

del +key1 +key2:删除key1和key2;删除成功返回2;


五、expire

expire的作用是给指定的key设定过期时间;key超出了指定的时间就会自动失效..

expire +key + seconds;设置成功返回1,设置失败返回0.

seconds为key有时效的秒数.

5.1 ttl命令

这个命令是为了判断一个key的剩余过期时间是多少;

ttl+key:返回某个key的剩余过期时间

如果返回-1说明没有设置过期时间;

如果返回-2说明已经过期;

5.2key删除策略

5.2.1惰性删除

key的过期时间到了,但是还没有删除,key还存在;当最后一次访问这个key的时候发现已经过期了就删除;

5.2.2定期删除

定期删除策略,并不一定是在一定时间内删除所有的key,而是每次抽取一部分的key,进行过期时间验证,也就是类似于一个抽查的过程;因为redis是单线程的程序,因此不太好一次遍历所有的key;否则容易造成宕机。


六、type

type+key的类型:返回当前的key的数据类型是什么;


key的数据类型

string

set key value ex +key有效的时间(设置某个key有效时间为10秒)

set key1 vlaue1 NX(某个key1不存在才设置,如果存在就返回nil)

set key2 value2 XX (某个key2存在才设置,存在则设置失败)

get key3:只支持字符串类型的value


incr:自增1,仅限数字类型

令某一个key增加1:

set key 10

incr key

get key:返回11;

incr操作的key如果不存在,那么就当作自增1来表示。


incrby key +一个具体的数量

对于某一个key的value增加10.


decr key

针对某一个数值的key执行-1操作.


incrbyfloat key +一个值

对于某一个key自增对应的一个值


append

set key hello;

append key world;==> key变成了:hello world


getrange key +start +end

getrange helloworld +0+-1

含义:截取这个字符串的从左边开始的第一个元素到从右边开始的第一个元素之间的字符串;

返回:helloworld;


getrange helloworld +1+-2

含义:截取这个字符串的从左边开始的第二个元素到从右边开始的第二个元素之间的字符串;

返回内容:elloworl


setrange key start+替换的字符串

setrange +helloworld + 1 +aaa

含义就是:从左往右的1号元素开始,也就是从字母e开始,往后替换三个字符为aaa.

==>haaaoworld


strlen key

返回的是key的长度==>包含的字符长度


hash

每一个hash类型的key,都是按照这样的结构存储的;在上图当中,key的名称是name1;

在这个key下面有好几个键值对:key-value;


hset key file1 value1

对于key设置:file1+value1

hget key file1

对于key,获取到file1的value是多少

hexists key file1

对于key,判断其中的file1属性是否存在

hdel key file1

删除的是key当中的file1

hkeys key

获取到key当中的所有hash的键;


list
lpush

lpush key 1 2 3 4==>含义是:使用头插法插入:1 2 3 4;因此执行完之后;在这个key当中元素的顺序是: 4,3,2,1

lrange

lrange key start end

这一个命令,相当于对于key做了一个截取操作,start的位置为从左往右的元素下表,end的位置为从从右往左的第一个元素下标;

rpush 

rpush key 1 2 3 4

这样,相当于尾插;这个时候key当中的元素存储顺序为:1 2 3 4;

lpop

从list左侧取出元素,相当于头删;

lindex 

lindex + key:返回的是下标对应的元素:如果一个list当中存在下面的元素:

1,2,3,4,5,6,7,8;

那么 lindex key 3==>返回的就是元素4;负数同理,从右往左计算索引。

llen key

返回key当中的list个数。


set

类似于JAVA当中的hashset数据结构;元素是无序的,并且不可以重复;

Set的常见操作

二.SET命令
集合的元素,代表 member 

SADD命令

        往集合当中添加元素,返回添加成功的元素个数。

语法: SADD key  member [member,member,...]

SMEMBERS 命令

        展示集合当中元素

语法 :SMEMBERS key

SISMEMBER 命令

        判断一个元素在不在set当中

语法:SISMEMBER  key member

SPOP命令

        一般表示从末尾删除元素,但由于set集合是无序的,此处是随机删除COUNT 个元素。

语法:pop key [count]

SRANDMEMBER命令

        随机获取集合当中的count个元素。

语法:srandmember key [count]

SMOVE 命令

        将一个元素从源set(source)取出,并且放入目标的set集合(destination)

语法:SMOVE SOURCE DESTINATION MEMBER

SREM 命令

        将集合set删除元素,一次删除多个个member

语法:srem key member [member ...]

集合之间的操作:交、并、差集

交集命令:SINTER key [key,key,...]     或者   SINTERSTORE  DESTINATION  key [key,key,...]    把结果放在DESTINATION当中。

并集命令:SUNION key [key ,...]    或者 SUNIONSTORE DESTINATION  key [key,key,...]    把结果放在DESTINATION当中。

差集命令:SDIFF key [key ,...]    或者 SDIFFSTORE DESTINATION  key [key,key,...]    把结果放在DESTINATION当中。


zset

Redis的zset数据类型,即有序集合(Sorted Set),是一种非常特别且有用的数据结构。以下是对zset数据类型的详细介绍及其常见操作的归纳:

一、zset数据类型概述

  1. 特性

    • zset是Redis中字符串类型元素的集合,且集合中的成员是唯一的,不允许重复。
    • 每个成员都会关联一个double类型的分数(score),这个分数用于对集合中的成员进行排序。分数可以重复。
    • 集合中的成员会根据分数从小到大进行排序,如果分数相同,则按照字典顺序排序。
  2. 底层实现

    • 在Redis的早期版本中,zset的底层数据结构可以是压缩列表(zipList)或跳表(skipList)。
    • 当有序集合的元素个数小于一定数量(如128个)且每个元素的值小于一定字节数(如64字节)时,Redis会使用压缩列表作为底层数据结构。
    • 当不满足上述条件时,Redis会使用跳表作为底层数据结构。
    • 在Redis 7.0及更高版本中,压缩列表数据结构已经被废弃,改由listpack数据结构实现。

二、zset的常见操作

  1. 添加元素

    • 使用ZADD命令向zset中添加一个或多个元素,并指定它们的分数。
    • 语法:ZADD key score1 member1 [score2 member2 ...]
  2. 获取元素

    • 使用ZRANGE命令获取zset中指定排名范围内的元素,可以选择是否同时返回分数。
    • 语法:ZRANGE key start stop [WITHSCORES]
    • 类似地,ZREVRANGE命令可以获取zset中指定排名范围内的元素,但按分数从高到低排序。
  3. 获取元素数量

    • 使用ZCARD命令获取zset中元素的数量。
    • 语法:ZCARD key
  4. 获取元素排名

    • 使用ZRANK命令获取元素在zset中的排名(从0开始,按分数从小到大排序)。
    • 语法:ZRANK key member
    • 类似地,ZREVRANK命令可以获取元素在zset中的排名,但按分数从高到低排序。
  5. 获取元素分数

    • 使用ZSCORE命令获取元素的分数。
    • 语法:ZSCORE key member
  6. 删除元素

    • 使用ZREM命令从zset中删除一个或多个元素。
    • 语法:ZREM key member [member ...]
  7. 为元素分数增加增量

    • 使用ZINCRBY命令为元素的分数加上指定的增量。
    • 语法:ZINCRBY key increment member
  8. 按分数范围获取元素

    • 使用ZRANGEBYSCORE命令获取zset中分数在指定范围内的元素,可以选择是否同时返回分数。
    • 语法:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
    • 类似地,ZREVRANGEBYSCORE命令可以获取zset中分数在指定范围内的元素,但按分数从高到低排序。
  9. 按分数范围删除元素

    • 使用ZREMRANGEBYSCORE命令删除zset中分数在指定范围内的元素。
    • 语法:ZREMRANGEBYSCORE key min max
  10. 按排名范围删除元素

    • 使用ZREMRANGEBYRANK命令删除zset中指定排名范围内的元素。
    • 语法:ZREMRANGEBYRANK key start stop
  11. 交集和并集操作

    • 使用ZINTERSTORE命令计算多个zset的交集,并将结果存储在新的zset中。可以指定每个zset的权重和聚合方式。
    • 语法:ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE sum|min|max]
    • 使用ZUNIONSTORE命令计算多个zset的并集,并将结果存储在新的zset中。同样可以指定权重和聚合方式。

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

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

相关文章

Windows安全加固详解

一、补丁管理 使用适当的命令或工具&#xff0c;检查系统中是否有未安装的更新补丁。 Systeminfo 尝试手动安装一个系统更新补丁。 • 下载适当的补丁文件。 • 打开命令提示符或PowerShell&#xff0c;并运行 wusa.exe <patch_file_name>.msu。 二、账号管…

Pikachu-Sql-Inject - 暴力破解

之前的破解&#xff0c;一般都需要 information_schema.schemata 、 information_schema.tables 、information_schema.columns 的权限&#xff0c;如果没有权限&#xff0c;就需要暴力破解&#xff1b; 如构造payload ,这个 abc 表就是我们要确定是否存在的表 vince and ex…

GPTQ vs AWQ vs GGUF(GGML) 速览和 GGUF 文件命名规范

简单介绍一下四者的区别。 参考链接&#xff1a;GPTQ - 2210.17323 | AWQ - 2306.00978 | GGML | GGUF - docs | What is GGUF and GGML? 文章目录 GPTQ vs AWQ vs GGUF&#xff08;GGML&#xff09; 速览GGUF 文件命名GGUF 文件结构文件名解析答案 附录GGUF 文件命名GGUF 文件…

Pandas基础学习

导入 导入pandas一般是这样导入的 import pandas as pdSeries 创建 s1 pd.Series([5, 17, 3, 26, 31])注意Series的第一个字母要大写&#xff0c;表明这其实是Series类的构建函数, 返回的是Series类的实例 获得元素或者索引 单独获得元素 s1.values单独获得索引值 s…

Flink 03 | 数据流基本操作

Flink数据流结构 DataStream 转换 通常我们需要分析的业务数据可能存在如下问题&#xff1a; 数据中包含一些我们不需要的数据 数据格式不方面分析 因此我们需要对原始数据流进行加工&#xff0c;比如过滤、转换等操作才可以进行数据分析。 “ Flink DataStream 转换主要作…

Kubernetes-环境篇-01-mac开发环境搭建

1、brew安装 参考知乎文章&#xff1a;https://zhuanlan.zhihu.com/p/111014448 苹果电脑 常规安装脚本&#xff08;推荐 完全体 几分钟安装完成&#xff09; /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)"苹果电脑 极…

【Android】中级控件

其他布局 相对布局RelativeLayout RelativeLayout下级视图的位置是相对位置&#xff0c;得有具体的参照物才能确定最终位置。如果不设定下级视图的参照物&#xff0c;那么下级视图默认显示在RelativeLayout内部的左上角。用于确定视图位置的参照物分两种&#xff0c;一种是与…

自动驾驶系列—全面解析自动驾驶线控制动技术:智能驾驶的关键执行器

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

JavaScript-上篇

JS 入门 JS概述 JavaScript&#xff08;简称JS&#xff09;是一种高层次、解释型的编程语言&#xff0c;最初由布兰登艾奇&#xff08;Brendan Eich&#xff09;于1995年创建&#xff0c;并首次出现在网景浏览器中。JS的设计初衷是为Web页面提供动态交互功能&#xff…

Leetcode - 140双周赛

目录 一&#xff0c;3300. 替换为数位和以后的最小元素 二&#xff0c;3301. 高度互不相同的最大塔高和 三&#xff0c;3302. 字典序最小的合法序列 四&#xff0c;3303. 第一个几乎相等子字符串的下标 一&#xff0c;3300. 替换为数位和以后的最小元素 本题直接暴力求解&a…

【hot100-java】【将有序数组转换为二叉搜索树】

二叉树篇 BST树 递归直接实现。 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNo…

wpf实现新用户页面引导

第一步 第二部 部分代码: private void show(int xh, FrameworkElement fe, string con, Visibility vis Visibility.Visible) {Point point fe.TransformToAncestor(Window.GetWindow(fe)).Transform(new Point(0, 0));//获取控件坐标点RectangleGeometry rg new Rectangl…

Deathnote解题过程

主机扫描&#xff0c;发现192.168.1.194 arp-scan -l 端口扫描&#xff0c;发现80和22端口 nmap -sS 192.168.1.194 访问80端口发现自动跳转到http://deathnote.vuln/wordpress添加绑定地址就可以访问了 vim /etc/hosts 192.168.1.194 deathnote.vuln 访问发现并没有什么东西…

无人值守安装文件

一般配合BypassUAC 原理 一些 windows 无人值守安装文件中含有用户的明文或 base64 编码后的密文。 无人值守安装文件中的密码不一定是管理员密码&#xff0c;它也可能是普通用户的密码或者服务账户的密码。 不过&#xff0c;在无人值守文件&#xff08;如 sysprep.xml 或 …

11.数据结构与算法-线性表的案例分析与实现

案例2.1-一元多项式的运算 案例2.2-稀疏多项式的计算 图书信息管理系统

2-112基于matlab的协同干扰功率分配模型

基于matlab的协同干扰功率分配模型&#xff0c;带操作界面的功率分配GUI&#xff0c;可以实现对已有功率的分配优化&#xff0c;可以手动输入参数值。4个干扰山区分二批总干扰功率&#xff0c;每个扇区包括威胁总系数、综合压制概率、目标函数增量等。程序已调通&#xff0c;可…

NVIDIA NVLink-C2C

NVIDIA NVLink-C2C 文章目录 前言一、介绍1. 用于定制芯片集成的超快芯片互连技术2. 构建半定制芯片设计3. 使用 NVLink-C2C 技术的产品 二、NVLink-C2C 技术优势1. 高带宽2. 低延迟3. 低功率和高密度4. 行业标准协议 前言 将 NVLink 扩展至芯片级集成 一、介绍 1. 用于定制芯…

【Java的SPI机制】Java SPI机制:实现灵活的服务扩展

在Java开发中&#xff0c;SPI&#xff08;Service Provider Interface&#xff0c;服务提供者接口&#xff09;机制是一种重要的设计模式&#xff0c;它允许在运行时动态地插入或更换组件实现&#xff0c;从而实现框架或库的扩展点。本文将深入浅出地介绍Java SPI机制&#xff…

Linux驱动开发(速记版)--设备模型

第八十章 设备模型基本框架-kobject 和 kset 80.1 什么是设备模型 设备模型使Linux内核处理复杂设备更高效。 字符设备驱动适用于简单设备&#xff0c;但对于电源管理和热插拔&#xff0c;不够灵活。 设备模型允许开发人员以高级方式描述硬件及关系&#xff0c;提供API处理设备…

kaggle实战3RossmanStore商店销售额预测XgBoost解决回归问题案例1

kaggle实战2信用卡反欺诈逻辑回归模型案例1 数据集下载地址 https://download.csdn.net/download/AnalogElectronic/89844637 https://tianchi.aliyun.com/dataset/89785 加载数据 #预测销售额 回归问题 import numpy as np import pandas as pd import matplotlib.pyplot a…