声明:本博客部分内容是从终极SpringBoot讲义摘抄的,文字是OCR识别出来的,有可能存在识别错误的可能,如有错误,请大胆指正,我马上修改!
目录
- 1.连接命令
- 2.key相关命令
- 3.String命令
- 4.List命令
- 5.Set命令
- 6.ZSet命令
- 7.Hash相关命令
- 8.事务相关命令
在介绍 Redis 的使用之前,先简单介绍一下Redis 的数据存储知识。Redis 使用key-value 结构来保存数据,其中 value 支持如下 5 种数据类型。
- Sting:最基本的数据类型,可保存任何数据。
- Hash:是key-value 集合(类似于 Java 的 Map),key 和value 都是String 类型的数据。这
种类型主要用于保存对象。 - List: 元素是String 类型的有序集合,集合中的元素可以重复。
- Set: 元素是 String 类型的无序集合,集合中的元素不能重复。
- ZSet:元素是 string 类型的有序集合,集合中的元素不能重复。
Redis 为不同数据类型提供了不同的操作命令,因此对于特定类型的数据需要使用对应类型的命令执行操作。
下面简单介绍一些 Redis 的常用命令。
1.连接命令
auth 【用户名】 【密码】
这里用户名可以省略,假如我的密码是123456可以直接
auth 123456
2.key相关命令
与key 相关的常用命令如下。
- DEL key:刪除key 対的 key-value 対。
- DUMP key:导出key 对应的值。
- EXISTS key: 判断key 是否存在。
- EXPIRE key seconds:设置key对应的key-value 对经过 seconds 秒后过期。
- EXPIREAT key timestamp:设置key 对应的key-value 对到timestamp 时过期。
- PEXPIRE key milliseconds: 设置 key 対的 key-value 对经过 milliseconds 毫秒后辻期。
- PEXPIREAT key milliseconds-timestamp: 设置 key 对应的 key-value 对到
milliseconds-timestamp 时过期。 - KEYS pattern: 返回匹配 pattern 的所有 key.
- MOVE key db:将指定 key 移动到db 数据库中。
- PERSIST key:删除key 的过期时间,key 将持久保持。
- PTTL key: 以毫秒为单位返回指定 key剩余的过期时间。
- TTL key:以秒为单位返回指定key剩余的过期时问。
- RANDOMKEY:从当前数据库返回一个随机的 key。
- RENAME key newkey: 将 key 重命名 newkey。
- RENAMENX key newkey: 相当手安全版的 RENAME, 当 newkey 不存在オ能重命名
- TYPE key:返回指定 key 存储的数据类型。
运行示例
3.String命令
正如前面所言,Redis 内不同数据类型提供了不同的操作命令,当 value 是 String 类型時,需要使用与 string 相关的命令进行操作。与 string 相关的常用命令如下。
- SET key value: 设置 key-value 対。
- GET key:返回指定key 对应的 value。
- GETRANGE key start end: 获取指定 key 対的 value 中心 start 到 end 的子串。
- GETSET key value: 指定 key 设置新的 value,非返回原来的 value。
- MGET key [key .]:返回一个(或多个)指定key 对应的 value。
- SETEX key seconds value:设置key-value 对,并设置过期时间为 seconds 秒。
- SETNX key value: SET 的安全版本,只有当key 不存在时才能设置该key-value 对。
- SETRANGE key offset value: 设置和覆盖指定key对应的 value,从原有 value 的 offset 个字符开始;如果key 不存在,则将前 offset 个字符设为空 (\N0000)。
- STRLEN key:获取 key对应的value 的字符串长度。
- MSET key value rkey value…]:设置多个key value对。
- MSETNX key value Tkey value…]: MSET 的安全版本,仅当所有key 都不存在时才能设置 成功。
- PSETEX key milliseconds value: SETEX 的毫秒版本,过期时间以毫秒计算。
- INCR key:将指定 key 中存储的整数值加 1。
- INCRBY key increment. 将指定key 中存修的整数値増加、inorement 整数值。
- INCRBYFLOAT key increment. INCRBY 的平点数版木,incremcnt 可以是小数。
- DECR Key:将指定 koy 中存储的整数值减1。
- DECRBY key decrement。将指定key 中存储的整数值少decrement整数值。
- APPEND key value 在指定key对应的字符串后追加新的value内容
4.List命令
List代表有序的集合,可通过命令为List添加或删除元素,List最多可包含232-1个元素。实际上,Redis的List也具有队列的性质,因此它包含了LPUSH
LPOP
RPUSH
RPOP
等命令,其中LPUSH
LPOP
表示从List的左边(队列头部)压入弹出元素;RPUSH
RPOP
表示从List的右边(队列尾部)压入弹出元素。
与List相关的常用命令如下。
➢ LINDEX key index:获取key对应的List的index处的元素。
➢ LINSERT key BEFORE|AFTER pivot value:在key对应的List的pivot元素之前或之后插入新的value元素。
➢ LLEN key:返回key对应的List的长度。
➢ LPOP key:弹出并返回key对应的List的第一个元素。
➢ LPUSH key value [value…]:向key对应的List的左边(队列头部)添加一个或多个元素。
➢ LPUSHX key value:LPUSH的安全版本,仅当key对应的List存在时有效。
➢ LRANGE key start stop:获取key对应的List中从start到stop范围内的元素。
➢ LREM key count value:从key对应的value中删除count个value元素。如果count大于0,则从左向右删除count个元素;如果count小于0,则从右向左删除count个元素;如果count等于0,则删除所有元素。
➢ LSET key index value:将key对应的List的index处的元素改为value。
➢ LTRIM key start stop:修剪List,只保留key对应的List中从start到stop之间的元素。
➢ RPOP key:弹出并返回key对应的List的最后一个元素。
➢ RPOPLPUSH source destination:弹出source的最后一个元素,添加到destination的左边(队列头部),并返回该元素。
➢ RPUSH key value [value…]:向key对应的List的右边(队列尾部)添加一个或多个元素。
➢ RPUSHX key value:RPUSH的安全版本,仅当key对应的List存在时有效。
➢ BLPOP key [key…] timeout:LPOP的阻塞版本。弹出并返回多个List的第一个元素,如果某个List没有元素,该命令会阻塞进
程,直到所有List都有元素弹出或超时。该命令的B代表Block。
➢ BRPOP key [key] timeout:RPOP的阻塞版本。弹出并返回多个List的最后一个元素,如果某个List没有元素,该命令会阻塞进
程,直到所有List都有元素弹出或超时。
➢ BRPOPLPUSH source destination timeout:RPOPLPUSH的阻塞版本,如果source中没有元素,该命令会阻塞进程,直到source有元
素弹出或超时。
5.Set命令
Set代表无序元素不能重复的集合,因此Set中的元素都是唯一的。Set最多可包含232-1个元素。Set底层其实是通过Hash表实现的,
因此它的删除查找的复杂度都是O(1),性能很好。
与Set相关的常用命令如下。
➢ SADD key member [member…]:向key对应的Set中添加一个
或多个元素。
➢ SCARD key:返回key对应的Set中元素的个数。
➢ SDIFF key [key…]:计算多个Set之间的差值。
➢ SDIFFSTORE destination key [key…]:SDIFF的存储版本,将多个Set之间的差值保存到destination中。
➢ SINTER key [key…]:返回给定Set的交集。
➢ SINTERSTORE destination key [key…]:SINTER的存储版本,将给定Set的交集保存到destination中。
➢ SISMEMBER key member:判断member是否为key对应的Set的元素。
➢ SMEMBERS key:返回key对应的Set的全部元素。
➢ SMOVE source destination member:将source中的member元素移到destination中。
➢ SPOP key:弹出key对应的Set中随机的一个元素。
➢ SRANDMEMBER key [count]:返回key对应的Set中随机的count个元素(不删除元素)。
➢ SREM key member [member…]:删除key对应的Set中的一个或多个元素。
➢ SUNION key [key…]:计算给定Set的并集。
➢ SUNIONSTORE destination key [key…]:SUNION的存储版本,将给定Set的并集保存到destination中。
6.ZSet命令
ZSet相当于Set 的增强版,它会为每个元素都分配一个double类型的score(分数),并按该score对集合中元素进行排序。
ZSet集合中的元素不允许重复,但元素的score是可以重复的。
与ZSet相关的常用命令如下。
➢ ZADD key score member [score member…]:向ZSet中添加一个或多个元素,或者更新已有元素的score。
➢ ZCARD key:返回key对应的ZSet中元素的个数。
➢ ZCOUNT key min max:返回ZSet中score位于min和max之间的元素个数。
➢ ZDIFF numkeys key [key…] [WITHSCORES]:计算给定ZSet之间的差值。该命令在Redis 6.2及更新版本中才可用。
➢ ZDIFFSTORE destination numkeys key [key…]:ZDIFF的存储版本,将给定ZSet之间的差值保存到destination中。该命令在Redi
s 6.2及更新版本中才可用。
➢ ZINCRBY key increment member:将memeber元素的score增加increment。
➢ ZINTER numkeys key [key…]:计算给定ZSet的交集。该命令在Redis 6.2及更新版本中才可用。
➢ ZINTERSTORE destination numkeys key [key…]:ZINTER的存储版本,将给定ZSet的交集保存到destination中。交集中元素的sc
ore是相同元素的score之和。
➢ ZLEXCOUNT key min max:返回ZSet中按字典排序时从min到max之间所有元素的个数。
提示:
当向ZSet中添加多个score相等的元素时,ZSet就会使用字典顺序
(英文字典中字母的排序方式)对这些元素进行排序,此时就可按字
典顺序来获取指定范围内元素的个数。
➢ ZPOPMAX key [count]:弹出ZSet中score最大的元素。
➢ BZPOPMAX key [key…] timeout:ZPOPMAX的阻塞版本。该命令会阻塞进程,直到指定ZSet有元素弹出或超时。
➢ ZPOPMIN key [count]:弹出ZSet中score最小的元素。
➢ BZPOPMIN key [key…] timeout:ZPOPMIN的阻塞版本。该命令会阻塞进程,直到指定ZSet有元素弹出或超时。
➢ ZRANGE key start stop [WITHSCORES]:返回ZSet中从start索引到stop索引范围内的元素(及score)。索引支持负数,负数表示
从最后面开始,比如-1代表最后一个元素。
➢ ZRANGEBYLEX key min max [LIMIT offset count]:返回ZSet
中按字典排序时从min到max之间的所有元素。
➢ ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]:返回ZSet中score位于min和max之间的所有元素。
➢ ZRANK key member:返回ZSet中指定元素的索引。score最小的元素的索引是0。
➢ ZREM key member [member…]:删除ZSet中一个或多个元素。
➢ ZREMRANGEBYLEX key min max:删除ZSet中按字典排序时从min到max之间的所有元素。
➢ ZREMRANGEBYRANK key start stop:删除ZSet中从start索引到stop索引之间的所有元素。
➢ ZREMRANGEBYSCORE key min max:删除ZSet中score位于min和max之间的所有元素。
➢ ZREVRANGE key start stop [WITHSCORES]:ZRANGE的反向版本。
➢ ZREVRANGEBYLEX key max min [LIMIT offset count]:ZRANGEBYLEX的反向版本。
➢ ZREVRANGEBYSCORE key max min [WITHSCORES]:ZRANGEBYSCORE的反向版本。
➢ ZREVRANK key member:ZRANK的反向版本。score最大的元素的反向索引是0。
➢ ZSCORE key member:获取指定元素的score。
➢ ZUNION numkeys key [key…]:计算给定ZSet的并集。该命令在Redis 6.2及更新版本中才可用。
➢ ZUNIONSTORE destination numkeys key [key…]:ZUNION的存储版本,将给定ZSet的并集保存到destination中。
➢ ZMSCORE key member [member…]:获取多个元素的score。该命令在Redis 6.2及更新版本中才可用。
7.Hash相关命令
Hash类型是一个key和value都是String类型的key-value对。Hash类型适合存储对象。每个Hash最多可存储232-1个key-value对。
与Hash相关的常用命令如下。
➢ HDEL key field [field…]:删除Hash对象中一个或多个key-value对。此处的field参数其实代表Hash对象中的key,后面提到的f
ield参数皆如此。
➢ HEXISTS key field:判断Hash对象中指定的key是否存在。
➢ HGET key field:获取Hash对象中指定key对应的value。
➢ HGETALL key:获取Hash对象中所有的key-value对。
➢ HINCRBY key field increment:为Hash对象中指定的key增加increment。
➢ HINCRBYFLOAT key field increment:HINCRBY的浮点数版本,支持小数。
➢ HKEYS key:获取Hash对象中所有的key。
➢ HLEN key:获取Hash对象中key-value对的数量。
➢ HMGET key field [field…]:HGET的加强版,可同时获取多个key对应的value。
➢ HSET key field value:为Hash对象设置一个key-value对。如果field对应的key已经存在,新设置的value将会覆盖原有的value。
➢ HMSET key field value [field value…]:HSET的加强版,可同时设置多个key-value对。
➢ HSETNX key field value:HSET的安全版本,只有当field对应的key不存在时,才能设置成功。
➢ HSTRLEN key field:获取Hash对象中指定key对应的value的字符串长度。
➢ HVALS key:获取Hash对象中所有的value。
8.事务相关命令
Redis事务保证事务内的多条命令会按顺序作为整体执行,其他客户端发出的请求绝不可能被插入到事务处理的中间,这样可以保证事
务内所有的命令作为一个隔离操作被执行。Redis事务同样具有原子性,事务内所有的命令要么全部被执行,要么全部被放弃。比如Redis在事务执行过程中遇到数据库宕机,假如事务已经执行了一半的命令,Redis将会自动回滚这些已经执行过的命令。注意某条命令执行出现错误并不会影响事务的提交。
与事务相关的常用命令如下。
➢ DISCARD:取消事务,放弃执行事务块内的所有命令。
➢ EXEC:执行事务。
➢ MULTI:开启事务。
➢ WATCH key [key…]:监视一个或多个key,如果在事务执行
之前这些key对应的值被其他命令改动,事务会自动中断。
➢ UNWATCH:取消WATCH命令对所有key的监视。