Redis 常用命令
Redis 常用命令,备查!
<部分内容摘抄自网络,如有侵权,预先道歉,请及时联系(rjguanwen001@163.com),我会尽快删除,谢谢!>
一、管理命令
1 启动 Redis
> redis-server [--port 6379]
如果命令参数过多,建议通过配置文件来启动 Redis。
> redis-server [xx/xx/redis.conf]
2 连接 Redis
> ./redis-cli [-h 127.0.0.1 -p 6379]
3 停止 Reids
> redis-cli shutdown
> kill redis-pid
以上两条命令,效果一样
4 发送命令
给 Redis 发送命令有两种方式: 1、redis-cli 带参数运行
> redis-cli <命令,如 shutdown>
2、redis-cli不带参数运行,先执行 redis-cli,进入命令行执行命令
5 测试连通性
> ping
二、key 操作命令
1 获取所有键
语法:keys pattern
> keys *
-
- 表示通配符,表示任意字符,会遍历所有键显示所有的键列表,时间复杂度O(n),在生产环境不建议使用。
2 获取键总数
语法:dbsize
- 获取键总数时不会遍历所有的键,直接获取内部变量,时间复杂度O(1)。
3 查询键是否存在
语法:exists key [key …]
- 可查询多个key,返回存在的个数。
4 删除键
语法:del key [key …]
- 可以删除多个key,返回删除成功的个数。
5 查询键类型
语法:type key
6 移动键
语法:move key db 如把 javastack 移到 2 号数据库:
> move javastack 2
(integer) 1
> select 2
OK
> keys *
1) "javastack"
7 查询 key 的生命周期(秒)
秒语法:ttl key 毫秒语法:pttl key
> ttl javastack
(integer) -1
- -1: 永不过期。
8 设置过期时间
秒语法:expire key seconds 毫秒语法:pexpire key milliseconds
9 设置永不过期
语法:persist key
10 更改键名称
语法:rename key newkey
三、字符串操作命令
字符串是Redis中最基本的数据类型,单个数据能存储的最大空间是512M。
1 存放键值
语法:set key value [EX seconds] [PX milliseconds] [NX|XX]
nx: 如果 key 不存在则建立;
xx: 如果 key 存在则修改其值;
2 获取键值
语法:get key
3 值递增/递减
如果字符串中的值是数字类型的,可以使用incr命令每次递增,不是数字类型则报错。
语法:incr key
如果字符串中的值是数字类型的,可以使用incr命令每次递增,不是数字类型则报错。
同样,递减使用decr、decrby命令。
4 批量存放键值
语法:mset key value [key value …]
5 批量获取键值
语法:mget key [key …]
Redis接收的是UTF-8的编码,如果是中文一个汉字将占3位返回。
6 获取值长度
语法:strlen key
7 追加内容
语法:append key value
向键值尾部拼接字符串。
8 获取部分字符
语法:getrange key start end
四、集合操作命令
集合类型和列表类型相似,只不过是集合是无序且不可重复的。
集合
1 存储值
语法:sadd key member [member …]
> sadd langs java php c++ go ruby python kotlin java
(integer) 7
2 获取元素
获取所有元素语法:smembers key
随机获取元素语法:srandmember key count
- 随机获取集合中 count 指定个数的元素
3 判断集合是否存在元素
语法:sismember key member
4 获取集合元素个数
语法:scard key
5 删除集合元素
语法:srem key member [member …]
6 弹出元素
语法:spop key [count]
有序集合
和列表的区别:
-
列表使用链表实现,两头快,中间慢。有序集合是散列表和跳跃表实现的,即使读取中间的元素也比较快。
-
列表不能调整元素位置,有序集合能。
-
有序集合比列表更占内存。
1 存储值
语法:zadd key [NX|XX] [CH] [INCR] score member [score member …]
> zadd fooCounts 16011 tid 20023 huny 2893 nosy
(integer) 3
2 获取元素分数
语法:zscore key member
> zscore footCounts tid
"16011"
获取指定范围排名语法:zrange key start stop [WITHSCORES]
// 获取所有,没有分数
> zrange footCounts 0 -1
1) "nosy"
2) "tid"
3) "huny"
// 获取所有及分数
> zrange footCounts 0 -1 Withscores
1) "nosy"
2) "2893"
3) "tid"
4) "16011"
5) "huny"
6) "20082"
获取指定分数范围排名语法:zrangebyscore key min max [WITHSCORES] [LIMIT offset count]
3 增加指定元素分数
zincrby key increment member
4 获取集合元素个数
语法:zcard key
5 获取指定范围分数个数
语法:zcount key min max
6 删除指定元素
语法:zrem key member [member …]
7 获取元素排名
语法 zrank key member
五、列表操作命令
列表类型是一个有序的字段串列表,内部是使用双向链表实现,所有可以向两端操作元素,获取两端的数据速度快,通过索引到具体的行数比较慢。
列表类型的元素是有序且可以重复的。
1 存储值
左端存值语法:lpush key value [value …] 右端存值语法:rpush key value [value …] 索引存值语法:lset key index value
2 弹出元素
左侧弹出语法:lpop key 右侧弹出语法:rpop key
3 获取元素个数
语法:llen key
4 获取列表元素
两边获取语法:lrange key start stop
> lpush users tom kitty land pony jack maddy
(integer) 6
> lrange users 0 3
1) "maddy"
2) "jack"
3) "pony"
4) "land"
// 获取所有
> lrange users 0 -1
1) "maddy"
2) "jack"
3) "pony"
4) "land"
5) "kitty"
6) "tom"
// 从右端索引
> lrange users -3 -1
1) "land"
2) "kitty"
3) "tom"
索引获取语法:lindex key index
> lindex list 2
"ketty"
// 从右端获取
> lindex list -5
"sady"
5 删除元素
根据值删除语法:lrem key count value
> lpush userids 111 222 111 222 222 333 222 222
(integer) 8
// count=0 删除所有
> lrem userids 0 111
(integer) 2
// count > 0 从左端删除前count个
> lrem userids 3 222
(integer) 3
// count < 0 从右端删除前count个
> lrem userids -3 222
(integer) 2
范围删除语法:ltrim key start stop
// 只保留2-4之间的元素
> ltrim list 2 4
OK
六、散列操作命令
redis字符串类型键和值是字典结构形式,这里的散列类型其值也可以是字典结构。
1 存放键值
单个语法:hset key field value
> hset user name javastack
(integer) 1
多个语法:hmset key field value [field value …]
> hmset user name javastack age 20 address china
OK
不存在时语法:hsetnx key field value
> hsetnx user tall 180
(integer) 0
2 获取字段值
单个语法:hget key field
> hget user age
"20"
多个语法:hmget key field [field …]
> hmget user name age address
1) "javastack"
2) "20"
3) "china"
获取所有键与值语法:hgetall key
> hgetall user
1) "name"
2) "javastack"
3) "age"
4) "20"
5) "address"
6) "china"
获取所有字段语法:hkeys key
> hkeys user
1) "name"
2) "address"
3) "tall"
4) "age"
获取所有值语法:hvals key
> hvals user
1) "javastack"
2) "china"
3) "170"
4) "20"
3 判断字段是否存在
语法:hexists key field
> hexists user address
(integer) 1
4 获取字段数量
语法:hlen key
> hlen user
(integer) 4
5 递增/减
语法:hincrby key field increment
> hincrby user tall -10
(integer) 170
6 删除字段
语法:hdel key field [filed …]