redis常用类型和使用场景
数据类型总览:
String类型
SET number 10086
SET story “Long, long ago there lived a king …”
SET msg “hello”
内部存储
- 字符串小于39个字节
- 短字符串优化编码方式
- 只调用一次内存分配函数
- 分配一块连续空间
常用命令
- SET:为一个key设置value,可以配合EX/PX参数指定key的有效期,通过NX/XX参数针对key是否存在的情况进行区别操作,时间复杂度O(1)
- GET:获取某个key对应的value,时间复杂度O(1)
- GETSET:为一个key设置value,并返回该key的原value,时间复杂度O(1)
- MSET:为多个key设置value,时间复杂度O(N)
- MSETNX:同MSET,如果指定的key中有任意一个已存在,则不进行任何操作,时间复杂度O(N)
- MGET:获取多个key对应的value,时间复杂度O(N)
- INCR:将key对应的value值自增1,并返回自增后的值。只对可以转换为整型的String数据起作用。时间复杂度O(1)
- INCRBY:将key对应的value值自增指定的整型数值,并返回自增后的值。只对可以转换为整型的String数据起作用。时间复杂度O(1)
- DECR/DECRBY:同INCR/INCRBY,自增改为自减。
使用场景
- 文章
- 库存控制
- 简单的计数器
List类型
RPUSH numbers 1 “three” 5
内部存储
参数配置
list-max-ziplist-entries 512
list-max-ziplist-value 64
常用命令
- LPUSH:向指定List的左侧(即头部)插入1个或多个元素,返回插入后的List长度。时间复杂度O(N),N为插入元素的数量
- RPUSH:同LPUSH,向指定List的右侧(即尾部)插入1或多个元素
- LPOP:从指定List的左侧(即头部)移除一个元素并返回,时间复杂度O(1)
- RPOP:同LPOP,从指定List的右侧(即尾部)移除1个元素并返回
- LPUSHX/RPUSHX:与LPUSH/RPUSH类似,区别在于,LPUSHX/RPUSHX操作的key如果不存在,则不会进行任何操作
- LLEN:返回指定List的长度,时间复杂度O(1)
- LRANGE:返回指定List中指定范围的元素(双端包含,即LRANGE key 0 10会返回11个元素),时间复杂度O(N)。应尽可能控制一次获取的元素数量,一次获取过大范围的List元素会导致延迟,同时对长度不可预知的List,避免使用LRANGE key 0 -1这样的完整遍历操作。
使用场景
- 队列
- 关注列表
- 评论列表
Hash类型
HSET profile name “tom”
HSET profile age 25
HSET profile carerr “Programmer”
内部存储
参数配置
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
常用命令
- HSET:将key对应的Hash中的field设置为value。如果该Hash不存在,会自动创建一个。时间复杂度O(1)
- HGET:返回指定Hash中field字段的值,时间复杂度O(1)
- HMSET/HMGET:同HSET和HGET,可以批量操作同一个key下的多个field,时间复杂度:O(N),N为一次操作的field数量
- HSETNX:同HSET,但如field已经存在,HSETNX不会进行任何操作,时间复杂度O(1)
- HEXISTS:判断指定Hash中field是否存在,存在返回1,不存在返回0,时间复杂度O(1)
- HDEL:删除指定Hash中的field(1个或多个),时间复杂度:O(N),N为操作的field数量
- HINCRBY:同INCRBY命令,对指定Hash中的一个field进行INCRBY,时间复杂度O(1)
- HGETALL:返回指定Hash中所有的field-value对。返回结果为数组,数组中field和value交替出现。时间复杂度O(N)
- HKEYS/HVALS:返回指定Hash中所有的field/value,时间复杂度O(N)
使用场景
- 用户资料
- 购物车
- 存储对象相关
Set类型
SADD numbers 1 3 5
SADD fruits “apple” “banana” “cherry”
内部存储
参数配置
set-max-intset-entries 512
注意:intset编码中集合对象中保存的所有元素都是int值
常用命令
- SADD:向指定Set中添加1个或多个member,如果指定Set不存在,会自动创建一个。时间复杂度O(N),N为添加的member个数
- SREM:从指定Set中移除1个或多个member,时间复杂度O(N),N为移除的member个数
- SRANDMEMBER:从指定Set中随机返回1个或多个member,时间复杂度O(N),N为返回的member个数
- SPOP:从指定Set中随机移除并返回count个member,时间复杂度O(N),N为移除的member个数
- SCARD:返回指定Set中的member个数,时间复杂度O(1)
- SISMEMBER:判断指定的value是否存在于指定Set中,时间复杂度O(1)
- SMOVE:将指定member从一个Set移至另一个Set
- SMEMBERS:返回指定Hash中所有的member,时间复杂度O(N)
- SUNION/SUNIONSTORE:计算多个Set的并集并返回/存储至另一个Set中,时间复杂度O(N),N为参与计算的所有集合的总member数
- SINTER/SINTERSTORE:计算多个Set的交集并返回/存储至另一个Set中,时间复杂度O(N),N为参与计算的所有集合的总member数
- SDIFF/SDIFFSTORE:计算1个Set与1或多个Set的差集并返回/存储至另一个Set中,时间复杂度O(N),N为参与计算的所有集合的总member数。
使用场景
- 与list相比可以排重
- 共同关注
- 共同喜好
Zset类型
ZADD price 8.5 apple 5.0 banana 6.0 cherry
内部存储
参数配置
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
常用命令
- ZADD:向指定Sorted Set中添加1个或多个member,时间复杂度O(Mlog(N)),M为添加的member数量,N为Sorted Set中的member数量
- ZREM:从指定Sorted Set中删除1个或多个member,时间复杂度O(Mlog(N)),M为删除的member数量,N为Sorted Set中的member数量
- ZCOUNT:返回指定Sorted Set中指定score范围内的member数量,时间复杂度:O(log(N))
- ZCARD:返回指定Sorted Set中的member数量,时间复杂度O(1)
- ZSCORE:返回指定Sorted Set中指定member的score,时间复杂度O(1)
- ZRANK/ZREVRANK:返回指定member在Sorted Set中的排名,ZRANK返回按升序排序的排名,ZREVRANK则返回按降序排序的排名。时间复杂度O(log(N))
- ZINCRBY:同INCRBY,对指定Sorted Set中的指定member的score进行自增,时间复杂度O(log(N))
- ZRANGE/ZREVRANGE:返回指定Sorted Set中指定排名范围内的所有member,ZRANGE为按score升序排序,ZREVRANGE为按score降序排序,时间复杂度O(log(N)+M),M为本次返回的member数
- ZRANGEBYSCORE/ZREVRANGEBYSCORE:返回指定Sorted Set中指定score范围内的所有member,返回结果以升序/降序排序,min和max可以指定为-inf和+inf,代表返回所有的member。时间复杂度O(log(N)+M)
- ZREMRANGEBYRANK/ZREMRANGEBYSCORE:移除Sorted Set中指定排名范围/指定score范围内的所有member。时间复杂度O(log(N)+M)
使用场景
- 排行榜
HyperLog类型
Redis 在 2.8.9 版本添加了 HyperLog 结构。
Redis HyperLog 是用来做基数统计的算法,HyperLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定 的、并且是很小的。
[email protected] ~]# redis-cli -p 60000
127.0.0.1:60000>
127.0.0.1:60000>
127.0.0.1:60000> PFADD winkey "mysql"
(integer) 1
127.0.0.1:60000> PFADD winkey "redis"
(integer) 1
127.0.0.1:60000> PFADD winkey "mongo"
(integer) 1
127.0.0.1:60000> PFCOUNT winkey
(integer) 3
127.0.0.1:60000> PFADD winkey "mongo"
(integer) 0
127.0.0.1:60000> PFCOUNT winkey
(integer) 3