redis常用指令

redis常用指令

一.基础操作

1.set key value

set key value : 设置 key,value 数据

set name lihua

可以不带双引号,如果有空格就要带

重复会覆盖值

2.get key

get key : 根据 key 查询对应的 value,如果不存在,返回空(nil)

3.clear

clear : 清除屏幕中的信息

4.quit/exit

quit/exit : 退出客户端 【说明: Redis 服务没有结束】

5.help

help 命令名称: 获取命令帮助文档,获取组中所有命令信息名称

6.keys *

keys * : 查看当前库所有 key (匹配:keys *1)

7.exists key

exists key:判断某个 key 是否存在

1存在,0不存在

8.type key

type key :查看你的 key 是什么类型

9.del key

del key : 删除指定的 key 数据

根据 value 选择非阻塞删除【仅将 keys 从 keyspace 元数据中删除,真正的删除会在后续异步操作】

11.expire key 时间

expire key 10 : 10 秒钟:为给定的 key 设置过期时间

12.ttl key

ttl key 查看还有多少秒过期,-1 表示永不过期,-2 表示已过期

13.select

select: 命令切换数据库

redis 安装后,默认有 16 个库, 0-15

默认操作的是 redis 的 0 号库

14.dbsize

dbsize:查看当前数据库的 key 的数量

15.flushdb

flushdb:清空当前库

16.flushall

flushall:清空全部库

二.五大数据类型

1.string

1.set 添加键值对

  1. get 查询对应键值
  2. append 将给定的 追加到原值的末尾
  3. strlen 获得值的长度
  4. setnx 只有在 key 不存在时 设置 key 的值
  5. incr 将 key 中储存的数字值(字符串)增 1, 只能对数字值操作,如果为空,新增值为1
  6. decr 将 key 中储存的数字值(字符串)减 1 , 只能对数字值操作,如果为空,新增值为-1
  7. incrby / decrby <步长>将 key 中储存的数字值增减。自定义步长
  8. mset ..., 同时设置一个或多个 key-value 对
  9. mget ... 同时获取一个或多个 value
  10. msetnx ... 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在, 原子性,有一个失败则都失败
  11. getrange <起始位置><结束位置> , 获得值的范围,类似 java 中的 substring,闭区间,负偏移量表示从字符串末尾开始计数,-1表示最后一个
  12. setrange <起始位置> 用 覆写所储存的字符串值,从<起始位置>开始(索引从 0 开始)
  13. setex <过期时间> 设置键值的同时,设置过期时间,单位秒。
  14. getset , 以新换旧,设置了新值同时获得旧值

2.list

list 类型, 保存多个数据,底层使用双向链表存储结构实现

1.lpush/rpush ... 从左边/右边插入一个或多个值

2.lpop/rpop 从左边/右边吐出一个值

3.rpoplpush 从列表右边吐出一个值,插到列表左边

4.lrange 按照索引下标获得元素(从左到右)
5.lrange mylist 0 -1 0 左边第一个,-1 右边第一个,(0-1 表示获取所有)
6.lindex 按照索引下标获得元素(从左到右
7.llen 获得列表长度
8.linsert before 在的前面插入插入值
9.lrem 从左边删除 n 个 value(从左到右)
10.lset将列表 key 下标为 index 的值替换成 value

3.set

set 提供的功能与 list 类似是一个列表的功能,特殊之处在于 set 是可以自动排

重的, 即值是不允许重复的

1.sadd ... 将一个或多个 member 元素加入到集合 key 中,已经存在的member 元素将被忽略

2.smembers 取出该集合的所有值

3.sismember 判断集合是否为含有该值,有 1,没有 0

4.scard返回该集合的元素个数。

5.srem ... 删除集合中的某个元素

6.spop 随机从该集合中吐出一个值

7.srandmember 随机从该集合中取出 n 个值。不会从集合中删除 。

8.smove value 把集合中一个值从一个集合移动到另一个集合

9.sinter 返回两个集合的交集元素

10.sunion 返回两个集合的并集元素

11.sdiff 返回两个集合的差集元素(key1 中的,不包含 key2 中的)

4.hash

Redis hash 是一个键值对集合,hash 适合用于存储对象, 类似 Java 里面的

Map<String,Object>

1.hset 给集合中的 键赋值

2.hget 从集合取出 value

3.hmset ... 批量设置 hash 的值 跟hset没啥区别

4.hmget ... 批量取出 hash 的 filed 值

5.hexists查看哈希表 key 中,给定域 field 是否存在

6.hkeys 列出该 hash 集合的所有 field

7.hvals 列出该 hash 集合的所有 value

8.hincrby 为哈希表 key 中的域 field 的值加上增量

9.hsetnx 将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在

5. zset

  1. Redis 有序集合 zset 与普通集合 set 非常相似,是一个没有重复元素的字符串集合。
  2. 不同之处是有序集合的每个成员都关联了一个评分(score),这个评分(score)被用来按照
    从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分可以是重复
    了 。
  3. 因为元素是有序的, 所以也可以很快的根据评分(score)或者次序(position)来获取一个范
    围的元素。
  4. 访问有序集合的中间元素也是非常快的, 你能够使用有序集合作为一个没有重复成员
    的列表。

1.zadd ... 将一个或多个 member 元素及其 score 值加入到有序集 key 当中

2.zrange [WITHSCORES] 返回有序集 key 中,下标在 之间的元素,带 WITHSCORES,可以让分数一起和值返回到结果集
3.zscore 返回有序集 key 中,成员 member 的 score 值
4.zrangebyscore key min max [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。
5.zrevrangebyscore key max min [withscores] [limit offset count] 同上,改为从大到小排列。
6.zincrby 为元素的 score 加上增量
7.zrem 删除该集合下,指定值的元素
8.zcount 统计该集合,分数区间内的元素个数
9.zrank 返回该值在集合中的排名,从 0 开始。

三.发布和订阅

1、PUBLISH channel msg

将信息 message 发送到指定的频道 channel

2、SUBSCRIBE channel [channel ...]

订阅频道,可以同时订阅多个频道

3、UNSUBSCRIBE [channel ...]

取消订阅指定的频道, 如果不指定频道,则会取消订阅所有频道

4、PSUBSCRIBE pattern [pattern ...]

订阅一个或多个符合给定模式的频道,每个模式以 * 作为匹配符,比如 it* 匹配所 有

以 it 开头的频道( it.news 、 it.blog 、 it.tweets 等等), news.* 匹配所有 以 news. 开

头的频道( news.it 、 news.global.today 等等),诸如此类

5、PUNSUBSCRIBE [pattern [pattern ...]]

退订指定的规则, 如果没有参数则会退订所有规则

相关推荐
王佑辉16 分钟前
【redis】redis缓存和数据库保证一致性的方案
redis·面试
小码的头发丝、1 小时前
Django中ListView 和 DetailView类的区别
数据库·python·django
Karoku0661 小时前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
gorgor在码农1 小时前
Redis 热key总结
java·redis·热key
想进大厂的小王1 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
Java 第一深情1 小时前
高性能分布式缓存Redis-数据管理与性能提升之道
redis·分布式·缓存
周全全2 小时前
MySQL报错解决:The user specified as a definer (‘root‘@‘%‘) does not exist
android·数据库·mysql
白云如幻2 小时前
MySQL的分组函数
数据库·mysql
荒川之神2 小时前
ORACLE 闪回技术简介
数据库·oracle
时差9533 小时前
【面试题】Hive 查询:如何查找用户连续三天登录的记录
大数据·数据库·hive·sql·面试·database