Redis常用的类型二
- lists
- hashes
- sets
- sorted sets
lists
底层是双向链表,有序(根据插入序有序)并且允许重复元素。
l开头基本上都是从左往右操作。
r开头基本上都是从右往左操作。
同向命令可以实现栈的操作,比如:lpush和lpop,rpush和rpop。
反向命令可以实现队列的操作,比如:lpush和rpop。
lrange
127.0.0.1:6379> lpush list1 v1 v2 v3 v4
(integer) 4
127.0.0.1:6379> lrange list1 0 -1
1) "v4"
2) "v3"
3) "v2"
4) "v1"
127.0.0.1:6379> lrange list1 0 -2
1) "v4"
2) "v3"
3) "v2"
127.0.0.1:6379>
还有可以基于数组操作
lindex
lset
lrem
linsert
127.0.0.1:6379> lindex list1 0
"v4"
127.0.0.1:6379> lset list1 -1 vvv
OK
127.0.0.1:6379> LRANGE list1 0 -1
1) "v4"
2) "v3"
3) "v2"
4) "vvv"
127.0.0.1:6379> lrem list1 -2 vvv
(integer) 1
127.0.0.1:6379> LRANGE list1 0 -1
1) "v4"
2) "v3"
3) "v2"
127.0.0.1:6379> LINSERT list1 after v2 vv
(integer) 4
127.0.0.1:6379> LRANGE list1 0 -1
1) "v4"
2) "v3"
3) "v2"
4) "vv"
127.0.0.1:6379> LINSERT list1 before v2 vv
(integer) 5
127.0.0.1:6379> LRANGE list1 0 -1
1) "v4"
2) "v3"
3) "vv"
4) "v2"
5) "vv"
127.0.0.1:6379>
blpop
阻塞等待某个key的value,0代表一直阻塞,配合 rpush
客户端一
127.0.0.1:6379> blpop k1 0
客户端二
127.0.0.1:6379> rpush k1 v1
(integer) 1
127.0.0.1:6379>
客户端一
127.0.0.1:6379> blpop k1 0
1) "k1"
2) "v1"
(17.57s)
127.0.0.1:6379>
hashes
redis的命令设计的很方便,都是h开头的,也有针对map value的计算指令 HINCRBY、HINCRBYFLOAT等。
也有人使用以下方式代表hash类型,个人感觉有点不严谨。
127.0.0.1:6379> set k1::mapkey mapValue
OK
127.0.0.1:6379> get k1::mapkey
"mapValue"
127.0.0.1:6379>
sets
Redis Set 是 String 的无序排列。
SADD
指令把新的元素添加到 set 中。对 set 也可做一些其他的操作,比如测试一个给定的元素是否存在,对不同 set 取交集,并集或差,等等
都是以s开头,方便记忆区分。
交集指令:sinter
、sinterstore
并集指令:sunion
、sunionstore
差集指令:sdiff
求差集,具有方向性,只求第一个key
随机取元素:srandmember
不会影响原来的数据
count的范围
正数:取出一个去重的结果集(不能超过已有集)
负数:取出一个带有重复的结果集,一定能满足数量
0:不返回
可在抽奖的场景使用:
可重复中奖(count负数)。
不可重复中奖(count正数)。
sorted sets
有序集,去重有序,元素需给出分值。
每个元素有正反向索引。
如果分值一样,按照名称的字典序排。
物理内存默认左小右大的,不会随命令发生变化,比如zrange和zrevrange
在添加的时候需要给出score。
127.0.0.1:6379> zadd set 0 v1 2 v2 3 v3
(integer) 3
127.0.0.1:6379> zrange set 0 -1
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> ZREVRANGE set 0 -1
1) "v3"
2) "v2"
3) "v1"
127.0.0.1:6379> type set
zset
127.0.0.1:6379> ZRANK set v2
(integer) 1
127.0.0.1:6379> ZRANK set v1
(integer) 0
127.0.0.1:6379> zadd set 4 v4
(integer) 1
127.0.0.1:6379> ZRANGE set 0 -1
1) "v1"
2) "v2"
3) "v3"
4) "v4"
127.0.0.1:6379> ZRANGE set 0 -1 -withscores
(error) ERR syntax error
127.0.0.1:6379> ZRANGE set 0 -1 withscores
1) "v1"
2) "0"
3) "v2"
4) "2"
5) "v3"
6) "3"
7) "v4"
8) "4"
127.0.0.1:6379>
底层结构是skiplist 跳表,每个元素增加后随机造层,用空间换时间的思想