Redis基础命令
⼀. 数据操作
1. 键命令
1.1 查找键
参数⽀持正则表达式
keys pattern
例1:查看所有键
keys *
例2:查看名称中包含 a 的键
keys a*
1.2 判断key是否存在
exists key 存在返回1 不存在返回0
1.3 查询
① 查看key对应的value的类型
type key
② 查看⽣存时间
ttl key -1 ⼀直不过期 -2 已过期
1.4 删除
del key
1.5 设置过期时间
以秒为单位,如果没有指定过期时间则⼀直存在,直到使⽤ DEL 移除
expire key seconds
2. string
字符串类型是Redis中最为基础的数据存储类型,它在Redis中是⼆进制安全的,可以接受任何格式
的数据,JPEG图像数据或Json对象描述信息等,在Redis中字符串类型的Value最多可以容纳的数
据⻓度是512M。
2.1 增加和修改
如果设置的键不存在则为添加,如果设置的键已经存在则修改
① 设置键值
set key value
② 设置键值及过期时间,以秒为单位
setex key seconds value
③ 设置多个键值
mset key1 value1 key2 value2 …
④ 追加值
append key value
2.2 查询
① 获取:根据键获取值,如果不存在此键则返回 nil
get key
② 根据多个键获取多个值
mget key1 key2 …
3.hash
hash⽤于存储对象,对象的结构为属性、值
值的类型为string
3.1增加和修改
① 设置单个属性
hset key field value
② 设置多个属性
hmset key field1 value1 field2 value2 …
3.2 查询
① 获取指定键所有的属性
hkeys key
② 获取⼀个属性的值
hget key field
③ 获取多个属性的值
hmget key field1 field2 …
④ 获取所有属性的值
hvals key
⑤ 获取所有的数据
hgetall key
3.3 删除
删除整个hash键及值,使⽤del命令
① 删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 …
3.4 可能出现的错误
Redis被配置为保存数据库快照,但它⽬前不能持久化到硬盘。⽤来修改集合数据的命令不能⽤
原因:
强制关闭Redis快照导致不能持久化。
解决⽅案:
运⾏config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-onbgsave-error解决该问题。
4. list类型
列表的元素类型为string
按照插⼊顺序排序
4.1 增加
① 在左侧插⼊数据
lpush key value1 value2 …
Redis lpush 命令将⼀个或多个值插⼊到列表头部。 如果 key 不存在,⼀个空列表会被创建并执⾏
LPUSH 操作。 当 key 存在但不是列表类型时,返回⼀个错误。
② 在右侧插⼊数据
rpush key value1 value2 …
③ 在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
4.2 修改
① 设置指定索引位置的元素值
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示尾部开始计数,如 -1 表示最后⼀个元素
lset key index value
4.3 查询
① 返回列表⾥指定范围内的元素
start 、 stop 为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如 -1 表示最后⼀个元素
lrange key start stop
4.4 删除
① 删除指定元素
将列表中前 count 次出现的值为 value 的元素移除
count > 0: 从头往尾移除
count < 0: 从尾往头移除
count = 0: 移除所有
lrem key count value
5. set类型
⽆序集合
元素为string类型
元素具有唯⼀性,不重复
说明:对于集合没有修改操作
5.1 增加
① 添加元素
sadd key member1 member2 …
5.2 查询
① 返回所有的元素
smembers key
5.3 删除
① 删除指定元素
srem key value
6. zset类型
sorted set,有序集合
元素为string类型
元素具有唯⼀性,不重复
每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
说明:没有修改操作
6.1 增加
zadd key score1 member1 score2 member2 …
6.2 查询
① 返回指定范围内的元素
start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如 -1 表示最后⼀个元素
zrange key start stop
② 返回 score 值在 min 和 max 之间的成员
zrangebyscore key min max
③ 返回成员 member 的 score 值
zscore key member
6.3 删除
① 删除指定元素
zrem key member1 member2 …
② 删除权重在指定范围的元素
zremrangebyscore key min max