List(有序,可重复)
双向链表,并且key中存有head和tail指针,可以快速的定位到list的首尾节点
l/r左右,以a,b,c为例,lpush:c,b,a rpush:a,b,c
lpush lpop/rpush rpop 同向命令,后进先出,栈
反向命令,先进先出,队列
lrange key start end 查询元素,这里面l表示集合
lindex key index 根据下标查询元素
lset key index value 设置列表中指定位数的值
lrem key count value 根据列表元素顺序,删除指定个数的值,(正负表示前后,在redis中基本都有正负索引)
linsert key before|after pivot value 在指定元素的前或者后插入元素
blpop/brpop 获取第一个元素并移除,去除最后一个元素并移除。阻塞状态,如果设置超时为0则一直阻塞。单播队列。
ltrim key start end 清除起始终止点,**以外**的元素
Hash
hset key filed value 单个设置key,及value hash值
hmset key filed1 value1 filed2 value2.. 批量设置
hget key filed 取出单个值
hmget key filed1 filed2 批量取出值
hkeys key 取出所有的键
hvals key 取出所有的值
hgetall key 取出所有的键值
hincrbyfloat key filed num 增加小数值
Set(无序,不可重复,随机性)
sadd key value1 value2 .. 设值
smembers key 取值
srem key1 key2 .. 移除
sinter key1 key2 取交集
sinterstore newkey key1 key2 取交集放到一个新key(作者减少了计算和再设值的过程IO)
sunion key1 key2 取并集
sunionstore key1 key2 取并集放到一个新key
sdiff key1 key2 取差集,按顺序不同取相应差集
srandmember key count 随机取出数
正数:取出一个去重的结果集(不能超过已有集)
负数:取出一个带重复的结果集,一定满足你要的数量
如果:0,不返回
spop key count 随机取出数
sorted-set(有序)
按物理大小顺序排序,不以命令不同所改变。值/分值/排名
zadd key score members 设值
zrange key start end (byscores) 取值,物理按左小右大取出
zrevrange key start end 取值,倒序取出
zrangebyscore key min max 取值,根据score区间取出
zscore key value 取值,根据value取出score
zrank key value 取值,根据value取出排名
zincrby key num value 给值增加分值
zunionstore newkey keysnum key1 key2 2新值,3要进行几个key的操作数,之后是要操作的key,默认是进行sum
zunionstore newkey keysnum key1 key2 weights w1 w2 带上权重计算*w1,*w2
zunionstore newkey keysnum key1 key2 aggregate sum|min|max 集合计算方式