Redis学习_常见基础命令
- Redis学习_常见基础命令
- 1、通用命令
- 2、Redis 的Key的操作命令
- 3、字符串类型的value操作命令
- 4、哈希类型的value操作命令
- 5、列表list类型的value操作命令
- 6、集合类型的value操作命令
- 7、有序集合类型的value 操作命令
Redis学习_常见基础命令
1、通用命令
- 【ping】沟通命令,查看状态,返回PONG
root@zimoqiufeng-virtual-machine:/usr/local/redis/redis-7.0.15# redis-cli
127.0.0.1:6379> ping
PONG
- 【dbsize】查看当前数据库中key的数目
127.0.0.1:6379> dbsize
(integer) 1
- 【select db】redis 默认十六个库,切换库命令
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]>
- 【flushdb】删除当前库的数据
127.0.0.1:6379[1]> set guanwanli guanwanli
OK
127.0.0.1:6379[1]> dbsize
(integer) 1
127.0.0.1:6379[1]> flushdb
OK
127.0.0.1:6379[1]> dbsize
(integer) 0
127.0.0.1:6379[1]>
- 【quit 或exit】退出当前redis 连接
quit
- 【redis-cli】登录自带redis命令行客户端
redis-cli
2、Redis 的Key的操作命令
-【keys pattern】 查看key
通配符:
* :表示 0-多个字符 ,例如:keys * 查询所有的 key , *表示 0 或多个字符
?:表示单个字符,例如:wo?d , 匹配 word , wood
127.0.0.1:6379[1]> keys *
1) "woood"
2) "guanwanli"
3) "wood"
4) "word"
127.0.0.1:6379[1]> keys wo*d
1) "woood"
2) "wood"
3) "word"
127.0.0.1:6379[1]> keys wo?d
1) "wood"
2) "word"
127.0.0.1:6379[1]> keys w*******d
1) "woood"
2) "wood"
3) "word"
-【exists key[key…]】 判断key是否存在
exists key
exists key1 key2
127.0.0.1:6379[1]> exists word wood hello
(integer) 2
127.0.0.1:6379[1]>
- 【expire key seconds】设置key的生存时间,超过时间,key自动删除。单位是秒
127.0.0.1:6379[1]> expire wood 3
(integer) 1
127.0.0.1:6379[1]> keys *
1) "woood"
2) "guanwanli"
3) "word"
127.0.0.1:6379[1]>
- 【ttl key】以秒为单位,返回key的剩余生存时间,返回值 -1:没有设置key的生存时间,key永不过期 -2:key不存在
127.0.0.1:6379[1]> expire woood 100
(integer) 1
127.0.0.1:6379[1]> ttl woood
(integer) 94
127.0.0.1:6379[1]>
- 【type key】查看key 所存储值的数据类型返回值:字符串表示的数据类型
none (key 不存在)
string(字符串)
list(列表)
set(集合)
zset(有序集)
hash(哈希表)
127.0.0.1:6379[1]> type word
string
- 【del key [key…】删除指定存在的 key ,不存在的 key 忽略。返回值:数字,删除的 key 的数量
127.0.0.1:6379[1]> del redis
(integer) 0
127.0.0.1:6379[1]> del word
(integer) 1
3、字符串类型的value操作命令
- 【set key value】将字符串值 value 设置到 key 中,已经存在的 key 设置新的 value,会覆盖原来的值。
127.0.0.1:6379[1]> set GitCode GitCode
OK
127.0.0.1:6379[1]> set InsCode InsCode
OK
127.0.0.1:6379[1]> set Blog blog
OK
-【get key】 获取 key 中设置的字符串值
127.0.0.1:6379[1]> get GitCode
"GitCode"
- 【incr key】将 key 中储存的数字值加 1,如果 key 不存在,则 key 的值先被初始化为 0 再执行 incr 操作(只能对数字类型的数据操作)
127.0.0.1:6379[1]> set index 1
OK
127.0.0.1:6379[1]> incr index
(integer) 2
127.0.0.1:6379[1]> get index
"2"
- 【decr key】将 key 中储存的数字值减1,如果 key 不存在,则么 key 的值先被初始化为 0 再执行 decr 操作(只能对数字类型的数据操作)
127.0.0.1:6379[1]> decr index
(integer) 1
127.0.0.1:6379[1]> decr myindex
(integer) -1
- 【append key value】 如果 key 存在, 则将 value 追加到 key 原来旧值的末尾如果 key 不存在, 则将再key 设置值为 value,返回值:追加字符串之后的总长度
127.0.0.1:6379[1]> get GitCode
"GitCode"
127.0.0.1:6379[1]> append GitCode 13
(integer) 9
127.0.0.1:6379[1]> get GitCode
"GitCode13"
- 【strlen key】返回 key 所储存的字符串值的长度返回值:如果key存在,返回字符串值的长度 key不存在,返回0
127.0.0.1:6379[1]> get username
"zhangsan"
127.0.0.1:6379[1]> strlen username
(integer) 8
- 【getrange key start end】获取 key 中字符串值从 start 开始 到 end 结束 的子字符串,包括 start 和 end,负数表示从字符串的末尾开始, -1 表示最后一个字符返回值:截取的子字符串。
127.0.0.1:6379[1]> get username
"zhangsan"
127.0.0.1:6379[1]> getrange username 1 3
"han"
127.0.0.1:6379[1]> getrange username -3 -2
"sa"
- 【setrange key offset value】用 value 覆盖(替换)key 的存储的值从 offset开始,不存在的 key 做空白字符串。返回值:修改后的字符串的长度
127.0.0.1:6379> get item
"javaCode"
127.0.0.1:6379> setrange item 2 av
(integer) 8
127.0.0.1:6379> get item
"jaavCode"
- 【mset key value [key value…]】同时设置一个或多个 key-value 对
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> get k2
"v2"
127.0.0.1:6379> get k3
"v3"
- 【mget key [key …]】获取(一个或多个)给定 key 的值 返回值:包含所有 key 的列表
127.0.0.1:6379> mget k1 k2 k3
1) "v1"
2) "v2"
3) "v3"
4、哈希类型的value操作命令
- 【hset hash 表的 key field value】哈希类型field(域 )和 value 的隐射表,value分为field和value,hset可将key中的值设置为value,如果 key 不存在,则新建 hash 表,执行赋值,如果有 field ,则覆盖值。
返回值:
如果 field 是 hash 表中新 field,且设置值成功,返回 1
如果 field 已经存在,旧值覆盖新值,返回 0
127.0.0.1:6379> hset website baidu http://www.baidu.com
(integer) 1
127.0.0.1:6379> hset website baidu www.baidu.com
(integer) 0
127.0.0.1:6379>
- 【hget key field】获取哈希表 key 中给定域 field 的值
返回值:field 域的值,如果 key 不存在或者 field 不存在返回 nil
127.0.0.1:6379> hget website baidu
"www.baidu.com"
127.0.0.1:6379> hget website google
(nil)
-【hmset key field value [field value…]】 同时将多个 field-value (域-值)设置到哈希表 key 中,此命令会覆盖已经存在的 field, 若hash 表 key 不存在,创建空的 hash 表,执行 hmset.
返回值:设置成功返回 ok, 如果失败返回一个错误
127.0.0.1:6379> hmset website baidu http://www.baidu.com google www.google.com
OK
- 【hmget key field [field…]】获取哈希表 key 中一个或多个给定域的值
返回值:返回和 field 顺序对应的值,如果 field 不存在,返回 nil
127.0.0.1:6379> hmget website baidu google
1) "http://www.baidu.com"
2) "www.google.com"
- 【hgetall key】获取哈希表 key 中所有的域和值
返回值:以列表形式返回 hash 中域和域的值 ,key 不存在,返回空 hash
127.0.0.1:6379> hgetall website
1) "baidu"
2) "http://www.baidu.com"
3) "google"
4) "www.google.com"
- 【hdel key field [field…]】删除哈希表 key 中指定域 field,不存在 field 直接忽略
返回值:成功删除的 field 的数量
127.0.0.1:6379> hgetall website
1) "baidu"
2) "http://www.baidu.com"
3) "google"
4) "www.google.com"
5) "aiqiyi"
6) "www.aiqiyi.com"
127.0.0.1:6379> hdel website aiqiyi
(integer) 1
127.0.0.1:6379> hgetall website
1) "baidu"
2) "http://www.baidu.com"
3) "google"
4) "www.google.com"
- 【hkeys key】查看哈希表 key 中的所有 field 域
返回值:包含所有 field 的列表,key 不存在返回空列表
127.0.0.1:6379> hkeys website
1) "baidu"
2) "google"
- 【hvals key】返回哈希表中所有域的值
返回值:包含哈希表所有域值的列表,key 不存在返回空列表
127.0.0.1:6379> hvals website
1) "http://www.baidu.com"
2) "www.google.com"
- 【hexists key field】查看哈希表 key 中,给定域 field 是否存在
返回值:如果 field 存在,返回 1, 其他返回 0
127.0.0.1:6379> hexists website baidu
(integer) 1
5、列表list类型的value操作命令
- 【lpush key value [value…]】将一个或多个值 value 插入到列表 key 的表头(最左边),从左边开始加入值,从左到右的顺序依次插入到表头,返回值:数字,新列表的长度
127.0.0.1:6379> lpush mylist a b c
(integer) 3
- 【rpush key value [value…]】将一个或多个值 value 插入到列表 key 的表尾(最右边),各个 value 值按从左到右的顺序依次插入到表尾
返回值:数字,新列表的长度
127.0.0.1:6379> rpush list2 a b c
(integer) 3
- 【lrange key start stop】 获取列表 key 中指定区间内的元素,0 表示列表的第一个元素,start , stop 是列表的下标值, -1 表示列表的最后一个元素, start ,stop 超出列表的范围不会出现错误。
返回值:指定区间的列表
127.0.0.1:6379> lpush mylist e f g
(integer) 6
127.0.0.1:6379> lrange mylist 0 5
1) "g"
2) "f"
3) "e"
4) "c"
5) "b"
6) "a"
- 【lindex key index】查询获取列表 key 中下标为指定 index 的元素,0 表示列表的第一个元素,start , stop 是列表的下标值, -1 表示列表的最后一个元素,
返回值:指定下标的元素;index 不在列表范围,返回 nil
lindex key index
- 【llen key】获取列表 key 的长度
返回值:数值,列表的长度; key 不存在返回 0
127.0.0.1:6379> llen mylist
(integer) 6
- 【lrem key count value】根据参数 count 的值,移除列表中与参数 value 相等的元素, count >0 ,从列表的左侧向右开始移除; count < 0 从列表的尾部开始移除;count = 0 移除表中所有与 value 相等的值。
返回值:数值,移除的元素个数
127.0.0.1:6379> lrem course 2 html
(integer) 2
127.0.0.1:6379> lrem course 0 java
(integer) 2
127.0.0.1:6379> lrange course 0 4
1) "mysql"
127.0.0.1:6379>
- 【lset key index value】将列表 key 下标为 index 的元素的值设置为 value。
返回值:设置成功返回 ok ; key 不存在或者 index 超出范围返回错误信息
127.0.0.1:6379> lset letter 2 c
OK
127.0.0.1:6379> lrange letter 0 -1
1) "e"
2) "d"
3) "c"
4) "b"
5) "a"
- 【linsert key BEFORE|ALFTER pivot value】将值 value 插入到列表 key 当中位于值 pivot 之前或之后的位置。key 不存在,pivot 不在列表中,不执行任何操作。
返回值:命令执行成功,返回新列表的长度。没有找到 pivot 返回 -1, key 不存在返回 0
127.0.0.1:6379> linsert arch BEFORE dao service
(integer) 3
127.0.0.1:6379> lrange arch 0 -1
1) "view"
2) "service"
3) "dao"
6、集合类型的value操作命令
-【sadd key member [member…]】 将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略,不会再加入。
返回值:加入到集合的新元素的个数。不包括被忽略的元素
127.0.0.1:6379> sadd sql update delete select
(integer) 3
127.0.0.1:6379> smembers sql
1) "select"
2) "delete"
3) "update"
- 【smembers key】获取集合 key 中的所有成员元素,不存在的 key 视为空集合
127.0.0.1:6379> sadd html-tag table href p
(integer) 3
127.0.0.1:6379> smembers html-tag
1) "p"
2) "href"
3) "table"
- 【sismember key member】判断 member 元素是否是集合 key 的成员
返回值:member 是集合成员返回 1,其他返回 0
127.0.0.1:6379> sismember course1 spring
(integer) 1
127.0.0.1:6379> sismember course1 redis
(integer) 0
- 【scard course】获取集合里面的元素个数
返回值:数字,key 的元素个数。 其他情况返回 0
127.0.0.1:6379> scard course1
(integer) 3
- 【srem key member [member…]】删除集合 key 中的一个或多个 member 元素,不存在的元素被忽略。
返回值:数字,成功删除的元素个数,不包括被忽略的元素。
127.0.0.1:6379> srem course1 html
(integer) 1
- 【srandmember key [count]】只提供 key,随机返回集合中一个元素;提供了 count 时,count 正数, 返回包含 count 个数元素的集合, 集合元素各不相同。count 是负数,返回一个 count 绝对值的长度的集合, 集合中元素可能会重复多次。如果count没填,随机返回一个值
返回值:一个元素;多个元素的集合
127.0.0.1:6379> srandmember course1 2
1) "spring"
2) "mysql"
127.0.0.1:6379> srandmember course1 2
1) "html"
2) "mysql"
- 【spop key [count]】随机从集合中删除一个元素, count 是删除的元素个数。
返回值:被删除的元素,key 不存在或空集合返回 nil
127.0.0.1:6379> spop course1
"html"
127.0.0.1:6379> smembers course1
1) "spring"
2) "mysql"
7、有序集合类型的value 操作命令
- 【zadd key score member [score member…]】将一个或多个 member 元素及其 score 值加入到有序集合 key 中,如果 member 存在集合中,则更新值;score 可以是整数或浮点数
返回值:数字,新添加的元素个数
127.0.0.1:6379> zadd studentscore 80 zhangsan 92 lisi 75 wangwu
(integer) 3
127.0.0.1:6379> zadd mycourse 82.25 html 75.56 mysql 92.5 java
(integer) 3
-【zrange key start stop [WITHSCORES]】 查询有序集合指定区间内的元素。集合成员按 score 值从小到大来排序。 start, stop 都是从 0 开始。0 是第一个元素,1 是第二个元素。以 -1 表示最后一个成员,-2 表示倒数第二个成员。使用WITHSCORES 选项让 score 和 value 一同返回。
返回值:自定区间的成员集合
显示集合的全部元素,不使用 WITHSCORES 则不显示 score
127.0.0.1:6379> zrange studentscore 0 -1
1) "wangwu"
2) "zhangsan"
3) "lisi"
显示集合全部元素,并使用 WITHSCORES
127.0.0.1:6379> zrange studentscore 0 -1 withscores
1) "wangwu"
2) "75"
3) "zhangsan"
4) "80"
5) "lisi"
6) "92"
显示0,1 二个成员
127.0.0.1:6379> zrange studentscore 0 1 withscores
1) "wangwu"
2) "75"
3) "zhangsan"
4) "80"
排序显示浮点数的 score
127.0.0.1:6379> zrange mycourse 0 -1 withscores
1) "mysql"
2) "75.560000000000002"
3) "html"
4) "82.25"
5) "java"
6) "92.5"
- 【zrevrange key start stop [WITHSCORES]】返回有序集 key 中,指定区间内的成员。其中成员的位置按 score 值递减(从大到小) 来排列。其它同 zrange 命令。
返回值:自定区间的成员集合
127.0.0.1:6379> zrevrange studentscore 0 -1 withscores
1) "lisi"
2) "92"
3) "zhangsan"
4) "80"
5) "wangwu"
6) "75"
- 【zrem key member [member…]】删除有序集合 key 中的一个或多个成员,不存在的成员被忽略
返回值:被成功删除的成员数量,不包括被忽略的成员。
127.0.0.1:6379> zrem studentscore wangwu
(integer) 1
127.0.0.1:6379> zrange studentscore 0 -1
1) "zhangsan"
2) "lisi"
- 【zcard key】获取有序集 key 的元素成员的个数返回值:key 存在返回集合元素的个数, key 不存在,返回 0
127.0.0.1:6379> zadd salary 3000 tom 6500 jack 2000 john
(integer) 3
127.0.0.1:6379> zcard salary
(integer) 3
127.0.0.1:6379> zadd salary 4500 rose
(integer) 1
127.0.0.1:6379> zcard salary
(integer) 4
- 【zrangebyscore key min max [WITHSCORES ] [LIMIT offset count]】获取有序集 key 中,所有 score 值介于 min 和 max 之间(包括 min 和 max)的成员,有序成员是按递增(从小到大)排序。
min ,max 是包括在内 , 使用符号 ( 表示不包括。 min , max 可以使用 -inf ,
+inf 表示最小和最大 limit 用来限制返回结果的数量和区间。 withscores 显示 score 和 value
返回值:指定区间的集合数据使用的准备数据
127.0.0.1:6379> zrange salary 0 -1 withscores
1) "john"
2) "2000"
3) "tom"
4) "3000"
5) "rose"
6) "4500"
7) "jack"
8) "6500"
127.0.0.1:6379> zrangebyscore salary 2000 4500 withscores
1) "john"
2) "2000"
3) "tom"
4) "3000"
5) "rose"
6) "4500"
显示指定具体区间的集合数据,开区间(不包括 min,max)
127.0.0.1:6379> zrangebyscore salary (2000 (4500 withscores
1) "tom"
2) "3000"
显示整个集合的所有数据
127.0.0.1:6379> zrangebyscore salary -inf +inf withscores
1) "john"
2) "2000"
3) "tom"
4) "3000"
5) "rose"
6) "4500"
7) "jack"
8) "6500"
使用 limit 增加新的数据
127.0.0.1:6379> zrange salary 0 -1 withscores1) "john"2) "2000"3) "tom"4) "3000"5) "marray"6) "3600"7) "rose"8) "4500"9) "jack"
10) "6500"
127.0.0.1:6379> zrangebyscore salary 3000 5000 withscores limit 0 2
1) "tom"
2) "3000"
3) "marray"
4) "3600"
-【zrevrangebyscore key max min [WITHSCORES ] [LIMIT offset count]】 返回有序集 key 中, score 值介于 max 和 min 之间(默认包括等于 max 或 min )的所有的成员。有序集成员按 score 值递减(从大到小)的次序排列。其他同 zrangebyscore
127.0.0.1:6379> zrevrangebyscore salary +inf 3000 withscores
1) "jack"
2) "6500"
3) "rose"
4) "4500"
5) "marray"
6) "3600"
7) "tom"
8) "3000"
- 【zcount key min max】 返回有序集 key 中, score 值在 min 和 max 之间(默认包括 score 值等于 min 或 max ) 的成员的数量
工资在 3000-5000 的员工数量
127.0.0.1:6379> zcount salary 3000 5000
(integer) 3