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

hash的常用指令

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 取交集,并集或差,等等

set的常用指令

都是以s开头,方便记忆区分。

交集指令:sintersinterstore

并集指令:sunionsunionstore

差集指令:sdiff

求差集,具有方向性,只求第一个key

随机取元素:srandmember

不会影响原来的数据

count的范围

正数:取出一个去重的结果集(不能超过已有集)

负数:取出一个带有重复的结果集,一定能满足数量

0:不返回

可在抽奖的场景使用:

可重复中奖(count负数)。

不可重复中奖(count正数)。

sorted sets

有序集,去重有序,元素需给出分值。

每个元素有正反向索引。

如果分值一样,按照名称的字典序排。

物理内存默认左小右大的,不会随命令发生变化,比如zrange和zrevrange

sorted_set常用指令

在添加的时候需要给出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 跳表,每个元素增加后随机造层,用空间换时间的思想

redis的key的重命名_客户端