一篇搞定Redis常用命令
wptr33 2024-12-31 15:03 68 浏览
满怀忧思,不如先干再说!
前言
上节我们说到Redis的下载和安装,本章说一下Redis的常用命令。基本要求是了解都有哪些命令,不同的数据类型如何存取数据即可。以便后期使用Java语言操作Redis的时候知道它的实现方式其实就是对命令的封装!!!
命令分类
- 通用命令
- 字符串类型
- 哈希类型
- 列表类型
- 集合类型
- 有序集合类型
通用命令
这里列出我们常用的命令,全部命令请参考redis官网:【平台限制:地址放到评论区】
keys pattern
说明:遍历出所有的key,*为pattern参数,也就是匹配符,类似于正则表达式,keys命令一般不推荐在生产环境中使用,因为如果我们的key非常多,检索起来就非常慢,这个命令比较重,而且redis是单线程的会阻塞其他的命令,如果我们需要检索key,可以使用scan命令
127.0.0.1:6379> keys *
1) "k1"dbsize
说明:计算key的总数
127.0.0.1:6379> dbsize
(integer) 1exists key
说明:查看key是否存在,返回值 1存在,0不存在
127.0.0.1:6379> exists k1
(integer) 1
127.0.0.1:6379> exists k2
(integer) 0del key[key...]
说明:删除指定的一个key或者一组key,返回值是删除key的个数
127.0.0.1:6379> del k1
(integer) 1expire key seconds
说明:设置key的过期时间,单位为秒,返回值1说明设置成功,返回0说明key不存在或设置失败
127.0.0.1:6379> expire k4 30
(integer) 1pexpire key milliseconds
说明:以毫秒为单位设置过期时间
127.0.0.1:6379> pexpire k5 90000
(integer) 1ttl key
说明:查看key的过期时间,以秒为单位,返回值-1永不过期,-2已过期
127.0.0.1:6379> ttl k5
(integer) 87pttl key
说明:查看key的过期时间以毫秒为单位
127.0.0.1:6379> pttl k1
(integer) 76151persist key
说明:移除key的过期时间
127.0.0.1:6379> persist k1
(integer) 1
127.0.0.1:6379> ttl k1
(integer) -1type key
说明:返回key对应的数据类型,分别为string、list、set、zset、hash五种数据类型,如果key不存在返回none
127.0.0.1:6379> type k1
string
127.0.0.1:6379> type k2
noneRedis实现原理
数据结构和内部编码
Redis中的五种数据结构,每一种都有两种以上的内部实现,多种内部编码实现可以在不同应用场景下发挥各自优势。具体的编码实现后边补充一篇文章单独去说!
redis单线程
redis是单线程的,在同一个瞬间只可能执行一条命令
那么为什么redis的单线程会这么快呢?
1、主要原因是redis是纯内存操作,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)速度非常快
2、使用多路I/O复用模型,非阻塞I/O
3、单线程避免线程切换和竞态消耗,单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程处理所有网络请求,其他模块仍用了多个线程。
注意
1、一次只执行一条命令
2、拒绝长(慢)命令
keys、flushall、flushdb、slow lua script等时间复杂度高的
String
说明
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。value可以是简单字符串,也可以是复杂的字符串比如JSON,XML等,也可以是数字(小数、整数),甚至是图片或者序列化后的对象,value是一个安全的二进制数据,string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
String类型的使用场景:用来做缓存、计数器、分布式锁等等。
常用命令
set key value : 设置 key 对应 string 类型的值, 返回 1 表示成功, 0 失败。(说明,设置key多次会覆盖)
setnx(not exist) key value: 如果 key 不存在进行设置,存在就不需要进行设置了,返回0
set key value [ex seconds/px milliseconds]: 设置值的同时设置过期时间
get key: 获取 key 对应的 string 值,如果 key 不存在返回 nil(在redis中nil代表为空)
getset key value : 先获取 key 的值,再设置 key 的值。
mset key1 value1 … : 一次设置多个 key 的值, 成功返回 1 表示所有的值都设置了,失败返回 0 表示没有任何值被设置。
mget key1 key2 … keyN : 一次获取多个 key 的值
msetnx key1 value1 … : 一次设置多个 key 的值,但是不会覆盖已经存在的 key
incr key: 递增,注意 incr 一个不是 int 的 value 会返回错误,incr 一个不在的 key,则设置 key 值为 1。
decr key : 递减, decr 一个不存在 key,则设置 key 值为-1。
incrby key integer: 对 key 加上指定值 , key 不存在设置 key,并认为原来的 value是 0。
decrby key integer: 对 key 减去指定值。decrby 完全是为了可读性,我们完全可以通过 incrby一个负值来实现同样效果,反之一样。
incrbyfloat key float:增加对应的浮点数,没有减去指定值,我们可以传入负数来实现该功能
append[key]方法: 字符串追加方法
strlen[key]方法: 获取字符串的长度
getrange key startindex endstart 获取指定范围的字符串
setrange key 10 value(10表示从第几位开始替换,后面跟上替换的字符串)Hash
说明
Hash类型是String类型的field和value的映射表,或者说一个String集合。它特别适合存储对象相比较而言,将一个对象类型存储在Hash类型里要比存储在String类型里占用更少的内存空间并方便存取整个对象
Hash应用场景:用一个对象来存储用户信息,商品信息,订单信息等等。
常用命令
hset key field value: 设置 hash field 为指定值,如果 key 不存在,则创建
hget key field : 获取指定的 hash field。
hmget key filed1…fieldN : 获取全部指定的 hash filed。
hmset key filed1 value1 … filedN valueN : 同时设置 hash 的多个 field。
hincrby key field integer: 指定步长增加。成功返回 hash filed 变更后的值。
hexists key field : 检测指定 field 是否存在。
hdel key field: 删除指定的 hash field。
hlen key: 返回指定 hash 的 field 数量。
hkeys key: 返回 hash 的所有 field。
hvals key : 返回 hash 的所有 value。
hgetall : 返回 hash 的所有 filed 和 value与String对比
存储用户信息使用String和Hash存储有什么区别?
使用String类型存储
用户ID为查找的key,存储的value用户对象包含姓名,年龄,生日等信息,如果用普通的key/value结构来存储,主要有以下2种存储方式:
方式一:
第一种方式将用户ID作为查找key,把其他信息封装成一个对象以序列化的方式存储,这种方式的缺点是,增加了序列化/反序列化的开销,并且在需要修改其中一项信息时,需要把整个对象取回,并且修改操作需要对并发进行保护,引入CAS等复杂问题。
方式二:
第二种方法是这个用户信息对象有多少成员就存成多少个key-value对,用户ID+对应属性的名称作为唯一标识来取得对应属性的值,虽然省去了序列化开销和并发问题,但是用户ID为重复存储,如果存在大量这样的数据,内存浪费还是非常可观的
Hash存储
Redis的Hash实际是内部存储的Value为一个HashMap,并提供了直接存取这个Map成员的接口,Key仍然是用户ID, value是一个Map,这个Map的key是成员的属性名,value是属性值,这样对数据的修改和存取都可以直接通过其内部Map的Key(Redis里称内部Map的key为field), 也就是通过 key(用户ID) + field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题,很好的解决了问题。
List
说明
list 列表是简单的字符串列表,按照插入顺序排序,数据可以重复。你可以添加一个元素到列表的头部(左边)或者尾部(右边),既可以作为栈,又可以作为队列
常用命令
lpush key string: 在 key 对应 list 的头部添加字符串元素,返回 1 表示成功, 0 表示 key 存在且不是 list 类型。
rpush key string: 在 key 对应 list 的尾部添加字符串元素
llen key: 返回 key 对应 list 的长度, 如果 key 不存在返回 0
lrange key start end: 返回指定区间内的元素, 下标从 0 开始, 负值表示从后面计算, -1 表示倒数第一个元素 , key 不存在返回空列表。
ltrim key start end : 截取 list 指定区间内元素,成功返回 OK, key 不存在返回错误。
lset key index value: 设置 list 中指定下标的元素值,成功返回 1, key 或者下标不存在返回错误。
lrem key count value : 从 List 的头部(count 正数)或尾部(count 负数)删除一定数量(count)匹配 value 的元素,返回删除的元素数量。count 为 0 时候删除全部。
lpop key: 从 list 的头部删除并返回删除元素。
rpop key: 从 list 的尾部删除并返回删除元素
rpoplpush source destination: 从source列表中删除最后一个元素,添加到des列表中第一个
lindex key index: 返回名称为key的list中index位置的元素
linsert key BEFORE|AFTER pivot value:把 value 插入存于 key 的列表中在基准值 pivot 的前面或后面List应用场景:好友列表,粉丝列表,消息队列,最新消息排行等
Set
说明
set是string类型的无序集合。集合是通过hashtable实现的,概念和数学中集合基本类似,可以交集,并集,差集等等,set中的元素是没有顺序并且不可重复。所以添加,删除,查找的复杂度都是O(1)
常用命令
sadd key member: 添加一个 string 元素到 key 对应 set 集合中,成功返回 1,如果元素以及在集合中则返回 0, key 对应的 set 不存在则返回错误。
srem key member: 从 key 对应 set 中移除指定元素,返回删除个数,集合中不存在或者key不存在返回 0,如果 key 对应的不是 set 类型的值返回错误。
spop key [count]: 删除并返回 key 对应 set 中随机的一个元素,如果 set 是空或者 key 不存在返回nil。
srandmember key [count]: 随机取 set 中的一个元素,但是不删除元素。
smove srckey dstkey member: 从 srckey 对应 set 中移除 member 并添加到 dstkey 对应 set 中,整个操作是原子的。 成功返回 1,如果 member 在 srckey 中不存在返回 0, 如果 key 不是 set类型返回错误。相当于剪切复制
scard key: 返回 set 的元素个数,如果 set 是空或者 key 不存在返回 0。
sismember key member: 判断 member 是否在 set 中,存在返回 1, 0 表示不存在或者 key 不存在。
sinter key1 key2 …… keyN : 返回所有给定 key 的交集。
sinterstore dstkey key1 … keyN : 返回所有给定 key 的交集, 并保存交集存到 dstkey 下。
sunion key1 key2 … keyN: 返回所有给定 key 的并集。
sunionstore dstkey key1 … keyN: 返回所有给定 key 的并集, 并保存并集到
dstkey sdiff key1 key2 … keyN: 返回所有给定 key 的差集。
sdiffstore dstkey key1 … keyN: 返回所有给定 key 的差集,并保存差集到
dstkey smembers key: 返回 key 对应 set 的所有元素,结果是无序的,如果集合中数据很多,不建议使用
scan key:扫描数据Set应用场景:共同关注、共同喜好、二度好友、分类标签等功能
sorted set(Zset)
说明
sorted set 是有序集合, 它在 set 的基础上增加了一个顺序属性(score),这一属性在添加,修改元素的时候可以指定, 每次指定后, 会自动重新按新的值调整顺序。 可以理解了有两列的mysql 表,一列存 value,一列存score
常用命令
zadd key score member: 添加元素到集合,元素在集合中存在则更新对应
score zrem key member: 删除指定元素, 1 表示成功,如果元素不存在返回 0
zincrby key incr member : 增加对应 member 的 score 值, 然后移动元素并保持 skip list 保持有序。返回更新后的 score 值
zrank key member : 返回指定元素在集合中的排名(下标), 集合中元素是按 score 从小到大排序的
zrevrank key member : 同上,但是集合中元素是按 score 从大到小排序
zrange key start end : 类似 lrange 操作从集合中去指定区间的元素。返回的是有序结果
zrevrange key start end: 同上,返回结果是按 score 逆序的
zrangebyscore key min max: 返回集合中 score 在给定区间的元素
zcount key min max: 返回集合中 score 在给定区间的数量 zcard key: 返回集合中元素个数
zscore key element: 返回给定元素对应的 scoresorted set使用场景:排行榜等
更多命令可以到Redis官网,因不能放置外链,将链接放到评论区,大家可以自行食用,如果不错记得关注,点赞哦!
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
-
- oracle数据导入导出_oracle数据导入导出工具
- 继续学习Python中的while true/break语句
- python continue和break的区别_python中break语句和continue语句的区别
- 简单学Python——关键字6——break和continue
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
- Python 中 break 和 continue 傻傻分不清
- python中的流程控制语句:continue、break 和 return使用方法
- L017:continue和break - 教程文案
- 作为前端开发者,你都经历过怎样的面试?
- 面试被问 const 是否不可变?这样回答才显功底
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
