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 数据
10.unlink 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 添加键值对
- get 查询对应键值
- append 将给定的 追加到原值的末尾
- strlen 获得值的长度
- setnx 只有在 key 不存在时 设置 key 的值
- incr 将 key 中储存的数字值(字符串)增 1, 只能对数字值操作,如果为空,新增值为1
- decr 将 key 中储存的数字值(字符串)减 1 , 只能对数字值操作,如果为空,新增值为-1
- incrby / decrby <步长>将 key 中储存的数字值增减。自定义步长
- mset ..., 同时设置一个或多个 key-value 对
- mget ... 同时获取一个或多个 value
- msetnx ... 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在, 原子性,有一个失败则都失败
- getrange <起始位置><结束位置> , 获得值的范围,类似 java 中的 substring,闭区间,负偏移量表示从字符串末尾开始计数,-1表示最后一个
- setrange <起始位置> 用 覆写所储存的字符串值,从<起始位置>开始(索引从 0 开始)
- setex <过期时间> 设置键值的同时,设置过期时间,单位秒。
- 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
- Redis 有序集合 zset 与普通集合 set 非常相似,是一个没有重复元素的字符串集合。
- 不同之处是有序集合的每个成员都关联了一个评分(score),这个评分(score)被用来按照
从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分可以是重复
了 。 - 因为元素是有序的, 所以也可以很快的根据评分(score)或者次序(position)来获取一个范
围的元素。 - 访问有序集合的中间元素也是非常快的, 你能够使用有序集合作为一个没有重复成员
的列表。
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 ...]]
退订指定的规则, 如果没有参数则会退订所有规则