Redis常用的五种数据结构及操作

Redis有5种常用的基础数据结构,string(字符串)、list(列表)、hash(字典)、set(集合)和zset(有序集合)

string(字符串)

Redis的字符串是可以修改的,内部实现类似于Java的ArrayList,采用预分配冗余空间的方式来减少内存的频繁分配,分配的实际空间一般要高于实际字符串长度,字符串长度小于1MB时,扩容都是加倍现有的空间,长度超过1MB,扩容时一次只会多扩1MB的空间,最大长度为512MB
常用操作如下表所示:

命令 解释
get 查询key的值
set 添加key/value值
append 将给定的追加到原值的末尾
strlen 获取值的长度
senx 在key不存在时设置key的值
incr 将key中存储的数字值增1
decr 将key中存储的数字值减1
incrby/decrby 步长 将key中存储的数字值增减 自定义步长
mset 同时设置一个或多个key-value对
mget 同时获取一个或多个value
msetnx 同时设置一个或多个key-value对 且所有给定的key都不存在
getrange 获取值的范围
setrange 覆盖所存储的字符串值 从start_index开始
setex 设置键值的同时 设置过期时间 单位秒
getset 以新换旧 设置新值的同时获取旧值
exists key是否存在
del 删除key

list(列表)

单键多值,底层实现是双向链表,对两端的操作性能很高,通过索引下标的操作中间的节点性能会较差
常用操作如下表所示:

命令 解释
lpush/rpush 从左边/右边插入一个或多个值
lpop/rpop 从左边/右边取出一个值
rpoplpush 列表右边取出一个值 插到列表左边
lrange 返回存储在key的列表里指定范围内的元素
ltrim 截取指定范围内的元素
lindex 按照索引下标获取元素(从左到右)
llen 获取列表长度
linsert before 后面插入
lrem 从左边删除n个value(从左到右)

hash(字典)

相当于Java中的HashMap,是无序的,由数组 + 链表实现,Redis hash是一个string类型的field和value的映射表,用于存储对象
常用操作如下表所示:

命令 解释
hset 集合中的赋值
hget 集合取出value
hmset 批量设置hash的值
hexists key 查看哈希表key中 给定域field是否存在
hkeys 列出该hash集合的所有field
hvals 列出该hash集合的所有value
hincrby 为哈希表key中的域field的值加上增量increment
hsetnx 将哈希表key中的域field的值设置为value 且field不存在

set(集合)

Redis set是一个列表,是string类型的无序集合,可以自动排重
常见操作如下表所示:

命令 解释
sadd 将一个或多个元素加入到集合key中 已存在的元素忽略
smembers 取出该集合的所有值
sismember 判断集合是否含有该值 有返回1 没有返回0
scard 返回该集合的元素个数
srem 删除集合中某个元素
spop 随机从该集合中取出一个值
srandmember 随机从该集合中取出n个值 不会从集合中删除
sinter 返回两个集合的交集元素
sunion 返回两个集合的并集元素
sdiff 返回两个集合的差集元素

zset(有序集合)

Redis有序集合zset于普通集合set相似,是一个没有重复元素的字符串集合,每个元素都关联了一个评分(score),用来按照从最低分到最高分的方式排序集合中的成员,元素是唯一的,评分可以重复
常用操作如下表所示:

命令 解释
zadd 将一个或多个元素及其score值加入到有序集key中
zrange 返回有序集key中 下标在 之间的元素
zrangebyscore key min max [withscores] [limit offset count] 返回有序集key中 所有score值介于min和max之间的元素 按score递增次序排列
zrevrangebyscore key max min [withscores] [limit offset count] 返回有序集key中 所有score值介于min和max之间的元素 按score递减次序排列
zincrby 为元素的score加上增量
zrem 删除该集合下 指定值的元素
zcount 统计该集合 分数区间内的元素个数
zrank 返回该值在集合中的排名 从0开始

你可能感兴趣的:(redis,redis)