Redis数据类型

Redis数据类型

通用操作

# 判断key是否存在
127.0.0.1:6379> EXISTS name
(integer) 1
127.0.0.1:6379> EXISTS name1
(integer) 0


# 修改key名字
127.0.0.1:6379> RENAME name name2
OK

# 查看指定key的数据类型
127.0.0.1:6379> type name2
string
127.0.0.1:6379> type PHPREDIS_SESSION:5555fb82ae8b698030baad3da87f9a8b
string

# 删除key
127.0.0.1:6379> del name2
(integer) 1


# 查看一个key的生存时间
127.0.0.1:6379> ttl age
(integer) -1
127.0.0.1:6379> ttl PHPREDIS_SESSION:5555fb82ae8b698030baad3da87f9a8b
(integer) 1212

# 以秒为单位设置生存时间
127.0.0.1:6379> EXPIRE aaa 100

# 以毫秒为单位设置生存时间
127.0.0.1:6379> PEXPIRE aaa 100

# 取消生存时间
127.0.0.1:6379> PERSIST aaa

字符串类型操作(strings)

# 设置key
127.0.0.1:6379> set name zls
OK

# 设置多个key
127.0.0.1:6379> mset name zls name1 huanglong name2 wuyangke
OK

# 查看多个key值
127.0.0.1:6379> MGET name name1 name2
1) "zls"
2) "huanglong"
3) "wuyangke"

# 先获取一个key的值,再设置或者修改key值
127.0.0.1:6379> getset xxx 123
(nil)
127.0.0.1:6379> get xxx
"123"

# 设置key同时设置生存时间(秒为单位)
127.0.0.1:6379> set book hongloumeng ex 100
OK

# 设置key同时设置生存时间(毫秒为单位)
127.0.0.1:6379> set book hongloumeng px 100
OK

# 字符串自增
127.0.0.1:6379> incr zan
(integer) 1

# 指定增加数量
127.0.0.1:6379> incrby fans 10000
(integer) 10023

# 自减
127.0.0.1:6379> decr fans
(integer) 10012

# 执行自减数量
127.0.0.1:6379> decrby fans 1000
(integer) 9012

# 按照小数自增
127.0.0.1:6379> incrbyfloat zls 0.1
"1.4"

127.0.0.1:6379> del zls
(integer) 1

## 字符串追加
127.0.0.1:6379> APPEND name1 liquanyi
(integer) 17
127.0.0.1:6379> get name1
"huanglongliquanyi"

## 修改第N个字符
127.0.0.1:6379> setrange name1 5 L
(integer) 17
127.0.0.1:6379> get name1
"huangLongliquanyi"

# 查看一个key
127.0.0.1:6379> get name1
"huangLongliquanyi"


# 查看多个key
127.0.0.1:6379> mget name1 name2
1) "huangLongliquanyi"
2) "wuyangke"


# 查看字符串的长度
127.0.0.1:6379> strlen name1
(integer) 17
127.0.0.1:6379> strlen name2
(integer) 8

# 查看生存时间
127.0.0.1:6379> ttl name1   // 秒
(integer) 93
127.0.0.1:6379> pttl name1  // 毫秒
(integer) 91417

# 字符串截取
127.0.0.1:6379> getrange name1 0 4
"huang"

hash类型(字典类型)

应用场景:

存储部分变更的数据,如用户信息,商品信息等。
最接近表结构的一种类型。

# 创建key
hset keyname field value
hset student_id_1 name zls
hset student_id_1 name zls age 18 gender m
hmset student_id_1 name zls age 18 gender m

# 查询
hget keyname field
hget student_id_1 name

hgetall keyname
hgetall student_id_1

hmget student_id_1 name age

# 删除
127.0.0.1:6379> hdel student_id_1 age gender
(integer) 2
127.0.0.1:6379> hgetall student_id_1
127.0.0.1:6379> del student_id_1


# 改
127.0.0.1:6379> hset student_id_1 name zls age 18 gender m
(integer) 3
127.0.0.1:6379> hgetall student_id_1
 1) "fans"
 2) "8"
 3) "zan"
 4) "9"
 5) "name"
 6) "zls"
 7) "age"
 8) "18"
 9) "gender"
10) "m"

list类型(列表类型)

消息队列

在生活中,其实有很多的例子,都类似消息队列。

比如:工厂生产出来的面包,交给超市,商场来出售,客户通过超市,商场来买面包,客户不会针对某一个工厂去选择,只管从超市买出来,工厂也不会管是哪一个客户买了面包,只管生产出来之后,交给超市,商场来处理。

消息队列(Message Queue)是一种应用间的通信方式,消息发送后可以立即返回,有消息系统来确保信息的可靠专递,消息生产者只管把消息发布到MQ中而不管谁来取,消息消费者只管从MQ中取消息而不管谁发布的,这样发布者和使用者都不用知道对方的存在。

生产者 -> 消息队列 -> 消费者 kafka

为什么使用消息队列

首先,我们可以知道,消息队列是一种异步的工作机制,比如说日志收集系统,为了避免数据在传输过程中丢失,还有订单系统,下单后,会生成对应的单据,库存的扣减,消费信息的发送,一个下单,产生这么多的消息,都是通过一个操作的触发,然后将其他的消息放入消息队列中,依次产生。再就是很多网站的,秒杀活动之类的,前多少名用户会便宜,都是通过消息队列来实现的。

这些例子,都是通过消息队列,来实现,业务的解耦,最终数据的一致性,广播,错峰流控等等,从而完成业务的逻辑。

消息队列的产品

  • RabbitMQ(最早金融公司,OpenStack)
  • ZeroMQ(SaltStack)
  • RocketMQ
  • Kafka(Java)
  • Redis(消息队列)
kafka
在kafka中可以创建topic会话
topic会话组,可以重复消费,消费者取数据根据topic的偏移量来取


公司的OA系统使用Jira
公司的文档系统使用 confluence


127.0.0.1:6379> lpush access_log '10.0.0.1 - - [03/Sep/2022:03:38:41 +0800] "POST /index.php HTTP/1.1" 200 1500 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36" "-"'

127.0.0.1:6379> lpush access_log '10.0.0.1 - - [03/Sep/2022:03:54:09 +0800] "POST /index.php HTTP/1.1" 200 1500 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36" "-"'

# 将数据添加在可以的最右边
127.0.0.1:6379> rpush name1 hl
(integer) 1
127.0.0.1:6379> rpush name1 wyk
(integer) 2
127.0.0.1:6379> rpush name1 zls
(integer) 3

# 如果数据不存在则不创建
lpushx name2 hl

# 将数据插入到key的任意位置
127.0.0.1:6379> linsert name2 after hl hjx
after:在...之后
before:在...之前

# 查看key中的指定范围数据
127.0.0.1:6379> lrange name 0 2
(empty array)
127.0.0.1:6379> lrange name1 0 2
1) "hl"
2) "wyk"
3) "zls"

# 从key的最左边取出数据
127.0.0.1:6379> lpop name1
"hl"
127.0.0.1:6379> lpop name1
"wyk"
127.0.0.1:6379> lpop name1
"zls"

# 查看key的长度
127.0.0.1:6379> llen name1

lpush:左边写入
rpush:右边写入
lpop:左边取出
rpop:右边取出


# 将name1右边的数据取出,写入name2左边
127.0.0.1:6379> lrange name1 0 2
1) "wyk"
2) "hjx"
3) "xwq"
127.0.0.1:6379> lrange name2 0 2
1) "hl"
2) "hjx"
3) "zls"
127.0.0.1:6379> rpoplpush name1 name2
"xwq"
127.0.0.1:6379> lrange name2 0 2
1) "xwq"
2) "hl"
3) "hjx"
127.0.0.1:6379> lrange name2 0 3
1) "xwq"
2) "hl"
3) "hjx"
4) "zls"


## 删除
# 从左边开始删除指定个数元素 lrem
127.0.0.1:6379> lrange name2 0 100
 1) "hl"
 2) "hl"
 3) "hl"
 4) "hl"
 5) "hl"
 6) "hl"
 7) "xwq"
 8) "hl"
 9) "hjx"
10) "zls"
11) "hl"
12) "hl"
13) "hl"
14) "hl"
127.0.0.1:6379> lrem name2 7 hl
(integer) 7
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"
3) "zls"
4) "hl"
5) "hl"
6) "hl"
7) "hl"

# 保留指定下标的元素,其余的都删除
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"
3) "zls"
4) "hl"
5) "hl"
6) "hl"
7) "hl"
127.0.0.1:6379> ltrim name2 0 1
OK
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"

## 改
127.0.0.1:6379> lrange name1 0 100
1) "wyk"
2) "hjx"
127.0.0.1:6379> lset name1 0 xwq
OK
127.0.0.1:6379> lrange name1 0 100
1) "xwq"
2) "hjx"

## 查
# 按照索引查询
127.0.0.1:6379> lindex name1 1
"hjx"
127.0.0.1:6379> lindex name1 0
"xwq"
127.0.0.1:6379> lindex name1 2
(nil)
127.0.0.1:6379> lindex name1 -1   //最后一个元素
"hjx"

## 发朋友圈
127.0.0.1:6379> lpush wechat 'monday hl sb'
(integer) 1
127.0.0.1:6379> lpush wechat 'tiusiday hl yiran sb'
(integer) 2
127.0.0.1:6379> lpush wechat 'wensiday hl always sb'
(integer) 3

## 查看朋友圈
127.0.0.1:6379> lrange wechat 0 -1
1) "wensiday hl always sb"
2) "tiusiday hl yiran sb"
3) "monday hl sb"

set(集合类型)

组1:1 2 3 4 5
组2: 1 3 5 7 9

交集:1 3 5
并集:1 2 3 4 5 7 9
差集:2 4 7 9
# 创建集合
127.0.0.1:6379> sadd zls_fans wyk hl
(integer) 2
127.0.0.1:6379> sadd tly_fans mls gaofei wyk
(integer) 3

# 查
## 查询集合中的元素,有就返回1 没有就返回0
127.0.0.1:6379> sismember zls_fans hl
(integer) 1
127.0.0.1:6379> sismember zls_fans cls
(integer) 0

## 查询集合中的所有元素
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"

## 查询集合中元素数量
127.0.0.1:6379> scard zls_fans
(integer) 2
127.0.0.1:6379> scard tly_fans
(integer) 3


## 比较集合中的差异,取前面集合的不同之处
127.0.0.1:6379> sdiff hl_fans tly_fans zls_fans
1) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS tly_fans
1) "wyk"
2) "mls"
3) "gaofei"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> sdiff hl_fans tly_fans
1) "hl"
2) "xiaoxuesheng"
127.0.0.1:6379> sdiff tly_fans hl_fans 
1) "wyk"
2) "gaofei"
127.0.0.1:6379> sdiff tly_fans hl_fans zls_fans
1) "gaofei"


## 比较之后的差异,存放到新的集合中
127.0.0.1:6379> sdiffstore resault tly_fans hl_fans 
(integer) 2
127.0.0.1:6379> KEYS *
1) "hl_fans"
2) "resault"
3) "name2"
4) "tly_fans"
5) "name1"
6) "wechat"
7) "zls_fans"
127.0.0.1:6379> type resault
set
127.0.0.1:6379> scard resault
(integer) 2
127.0.0.1:6379> 
127.0.0.1:6379> SMEMBERS resault
1) "wyk"
2) "gaofei"

## 交集(共同好友)
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> sinter hl_fans zls_fans
1) "hl"

## 并集
127.0.0.1:6379> sunion hl_fans zls_fans
1) "hl"
2) "wyk"
3) "mls"
4) "xiaoxuesheng"

## 将交集存入新集合
127.0.0.1:6379> sinterstore new_set hl_fans zls_fans
(integer) 1
127.0.0.1:6379> SMEMBERS new_set
1) "hl"

## 将并集存入新集合
127.0.0.1:6379> sunionstore new_set2 hl_fans zls_fans
(integer) 4
127.0.0.1:6379> SMEMBERS new_set2
1) "hl"
2) "wyk"
3) "mls"
4) "xiaoxuesheng"

## 取随机值
127.0.0.1:6379> srandmember zls_fans
"mls"



## 改
## 将集合的元素存入另一个集合 SMOVE
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> SMOVE hl_fans zls_fans mls
(integer) 1
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
3) "mls"


## 删
127.0.0.1:6379> spop hl_fans
"hl"
127.0.0.1:6379> SMEMBERS hl_fans
1) "xiaoxuesheng"

## 删除指定元素,返回删除元素的个数
127.0.0.1:6379> srem zls_fans hl
(integer) 1
127.0.0.1:6379> SMEMBERS zls_fans
1) "wyk"
2) "mls"
127.0.0.1:6379> srem zls_fans xxx
(integer) 0


#### 无序的
127.0.0.1:6379> sadd zls_fans 111 222 333 444 555 666
(integer) 6
127.0.0.1:6379> SMEMBERS zls_fans
 1) "abc"
 2) "111"
 3) "mls"
 4) "123"
 5) "def"
 6) "333"
 7) "222"
 8) "456"
 9) "444"
10) "555"
11) "666"
12) "wyk"

sorted-set(有序集合)

应用场景:

排行榜应用,取TOP N操作
这个需求与上面需求的不同之处在于,前面操作以时间为权重,这个是以某个条件为权重,比如按顶的次数排序,这时候就需要我们的sorted set出马了,将你要排序的值设置成sorted set的score,将具体的数据设置成相应的value,每次只需要执行一条ZADD命令即可。

# 增
127.0.0.1:6379> zadd myzset 1 "one" 2 "two" 3 "three"

# 查
## 只查询成员
127.0.0.1:6379> zrange chengji 0 -1
1) "wyk"
2) "hl"
3) "zls"

## 查询成员和分数
127.0.0.1:6379> zrange chengji 0 -1 WITHSCORES
1) "wyk"
2) "1"
3) "hl"
4) "38"
5) "zls"
6) "100"

## 查询成员的索引
127.0.0.1:6379> zrank chengji wyk
(integer) 0
127.0.0.1:6379> zrank chengji zls
(integer) 2


## 查询成员数量
127.0.0.1:6379> zcard chengji 
(integer) 3

## 查看分数是指定范围的成员个数    30 <= score <=40
127.0.0.1:6379> zcount chengji 30 40
(integer) 1
127.0.0.1:6379> zcount chengji 30 101
(integer) 2

## 获取指定成员分数
127.0.0.1:6379> ZSCORE chengji wyk
"1"
127.0.0.1:6379> ZSCORE chengji zls
"100"

## 查看分数是指定范围的成员名
127.0.0.1:6379> zcount chengji 30 40
(integer) 1
127.0.0.1:6379> zrangebyscore chengji 30 40
1) "hl"

## +inf表示最后一个成员,-inf表示第一个成员,意思是:检索所有数据,然后从下标为2的数据开始再往后输出3:(N-1)个数据
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 3
1) "hjx"
2) "xwq"
3) "zls"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 2
1) "hjx"
2) "xwq"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 1
1) "hjx"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 4
1) "hjx"
2) "xwq"
3) "zls"

# 删
## 删除指定分数范围的成员,并返回删除的个数
127.0.0.1:6379> zrangebyscore chengji 30 40
1) "hl"
127.0.0.1:6379> zremrangebyscore chengji 30 40
(integer) 1

## 按指定索引范围删除,返回删除个数
127.0.0.1:6379> zremrangebyrank chengji 0 2
(integer) 3


## 倒序排名
127.0.0.1:6379> zrevrange chengji 0 -1 WITHSCORES
 1) "zls"
 2) "100"
 3) "hjx"
 4) "60"
 5) "xwq"
 6) "50"
 7) "hl"
 8) "38"
 9) "wyk"
10) "1"

## 按照分数段查找成员,并倒序排序
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES
1) "zls"
2) "100"
3) "hjx"
4) "60"
5) "xwq"
6) "50"
7) "hl"
8) "38"

## 按照分数查找成员,并倒序排序,然后按照索引号,取出指定的数据
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES limit 1 2
1) "hjx"
2) "60"
3) "xwq"
4) "50"
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES limit 1 3
1) "hjx"
2) "60"
3) "xwq"
4) "50"
5) "hl"
6) "38"

通用操作

# 判断key是否存在
127.0.0.1:6379> EXISTS name
(integer) 1
127.0.0.1:6379> EXISTS name1
(integer) 0


# 修改key名字
127.0.0.1:6379> RENAME name name2
OK

# 查看指定key的数据类型
127.0.0.1:6379> type name2
string
127.0.0.1:6379> type PHPREDIS_SESSION:5555fb82ae8b698030baad3da87f9a8b
string

# 删除key
127.0.0.1:6379> del name2
(integer) 1


# 查看一个key的生存时间
127.0.0.1:6379> ttl age
(integer) -1
127.0.0.1:6379> ttl PHPREDIS_SESSION:5555fb82ae8b698030baad3da87f9a8b
(integer) 1212

# 以秒为单位设置生存时间
127.0.0.1:6379> EXPIRE aaa 100

# 以毫秒为单位设置生存时间
127.0.0.1:6379> PEXPIRE aaa 100

# 取消生存时间
127.0.0.1:6379> PERSIST aaa

字符串类型操作(strings)

# 设置key
127.0.0.1:6379> set name zls
OK

# 设置多个key
127.0.0.1:6379> mset name zls name1 huanglong name2 wuyangke
OK

# 查看多个key值
127.0.0.1:6379> MGET name name1 name2
1) "zls"
2) "huanglong"
3) "wuyangke"

# 先获取一个key的值,再设置或者修改key值
127.0.0.1:6379> getset xxx 123
(nil)
127.0.0.1:6379> get xxx
"123"

# 设置key同时设置生存时间(秒为单位)
127.0.0.1:6379> set book hongloumeng ex 100
OK

# 设置key同时设置生存时间(毫秒为单位)
127.0.0.1:6379> set book hongloumeng px 100
OK

# 字符串自增
127.0.0.1:6379> incr zan
(integer) 1

# 指定增加数量
127.0.0.1:6379> incrby fans 10000
(integer) 10023

# 自减
127.0.0.1:6379> decr fans
(integer) 10012

# 执行自减数量
127.0.0.1:6379> decrby fans 1000
(integer) 9012

# 按照小数自增
127.0.0.1:6379> incrbyfloat zls 0.1
"1.4"

127.0.0.1:6379> del zls
(integer) 1

## 字符串追加
127.0.0.1:6379> APPEND name1 liquanyi
(integer) 17
127.0.0.1:6379> get name1
"huanglongliquanyi"

## 修改第N个字符
127.0.0.1:6379> setrange name1 5 L
(integer) 17
127.0.0.1:6379> get name1
"huangLongliquanyi"

# 查看一个key
127.0.0.1:6379> get name1
"huangLongliquanyi"


# 查看多个key
127.0.0.1:6379> mget name1 name2
1) "huangLongliquanyi"
2) "wuyangke"


# 查看字符串的长度
127.0.0.1:6379> strlen name1
(integer) 17
127.0.0.1:6379> strlen name2
(integer) 8

# 查看生存时间
127.0.0.1:6379> ttl name1   // 秒
(integer) 93
127.0.0.1:6379> pttl name1  // 毫秒
(integer) 91417

# 字符串截取
127.0.0.1:6379> getrange name1 0 4
"huang"

hash类型(字典类型)

应用场景:

存储部分变更的数据,如用户信息,商品信息等。
最接近表结构的一种类型。

# 创建key
hset keyname field value
hset student_id_1 name zls
hset student_id_1 name zls age 18 gender m
hmset student_id_1 name zls age 18 gender m

# 查询
hget keyname field
hget student_id_1 name

hgetall keyname
hgetall student_id_1

hmget student_id_1 name age

# 删除
127.0.0.1:6379> hdel student_id_1 age gender
(integer) 2
127.0.0.1:6379> hgetall student_id_1
127.0.0.1:6379> del student_id_1


# 改
127.0.0.1:6379> hset student_id_1 name zls age 18 gender m
(integer) 3
127.0.0.1:6379> hgetall student_id_1
 1) "fans"
 2) "8"
 3) "zan"
 4) "9"
 5) "name"
 6) "zls"
 7) "age"
 8) "18"
 9) "gender"
10) "m"

list类型(列表类型)

消息队列

在生活中,其实有很多的例子,都类似消息队列。

比如:工厂生产出来的面包,交给超市,商场来出售,客户通过超市,商场来买面包,客户不会针对某一个工厂去选择,只管从超市买出来,工厂也不会管是哪一个客户买了面包,只管生产出来之后,交给超市,商场来处理。

消息队列(Message Queue)是一种应用间的通信方式,消息发送后可以立即返回,有消息系统来确保信息的可靠专递,消息生产者只管把消息发布到MQ中而不管谁来取,消息消费者只管从MQ中取消息而不管谁发布的,这样发布者和使用者都不用知道对方的存在。

生产者 -> 消息队列 -> 消费者 kafka

为什么使用消息队列

首先,我们可以知道,消息队列是一种异步的工作机制,比如说日志收集系统,为了避免数据在传输过程中丢失,还有订单系统,下单后,会生成对应的单据,库存的扣减,消费信息的发送,一个下单,产生这么多的消息,都是通过一个操作的触发,然后将其他的消息放入消息队列中,依次产生。再就是很多网站的,秒杀活动之类的,前多少名用户会便宜,都是通过消息队列来实现的。

这些例子,都是通过消息队列,来实现,业务的解耦,最终数据的一致性,广播,错峰流控等等,从而完成业务的逻辑。

消息队列的产品

  • RabbitMQ(最早金融公司,OpenStack)
  • ZeroMQ(SaltStack)
  • RocketMQ
  • Kafka(Java)
  • Redis(消息队列)
kafka
在kafka中可以创建topic会话
topic会话组,可以重复消费,消费者取数据根据topic的偏移量来取


公司的OA系统使用Jira
公司的文档系统使用 confluence


127.0.0.1:6379> lpush access_log '10.0.0.1 - - [03/Sep/2022:03:38:41 +0800] "POST /index.php HTTP/1.1" 200 1500 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36" "-"'

127.0.0.1:6379> lpush access_log '10.0.0.1 - - [03/Sep/2022:03:54:09 +0800] "POST /index.php HTTP/1.1" 200 1500 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36" "-"'

# 将数据添加在可以的最右边
127.0.0.1:6379> rpush name1 hl
(integer) 1
127.0.0.1:6379> rpush name1 wyk
(integer) 2
127.0.0.1:6379> rpush name1 zls
(integer) 3

# 如果数据不存在则不创建
lpushx name2 hl

# 将数据插入到key的任意位置
127.0.0.1:6379> linsert name2 after hl hjx
after:在...之后
before:在...之前

# 查看key中的指定范围数据
127.0.0.1:6379> lrange name 0 2
(empty array)
127.0.0.1:6379> lrange name1 0 2
1) "hl"
2) "wyk"
3) "zls"

# 从key的最左边取出数据
127.0.0.1:6379> lpop name1
"hl"
127.0.0.1:6379> lpop name1
"wyk"
127.0.0.1:6379> lpop name1
"zls"

# 查看key的长度
127.0.0.1:6379> llen name1

lpush:左边写入
rpush:右边写入
lpop:左边取出
rpop:右边取出


# 将name1右边的数据取出,写入name2左边
127.0.0.1:6379> lrange name1 0 2
1) "wyk"
2) "hjx"
3) "xwq"
127.0.0.1:6379> lrange name2 0 2
1) "hl"
2) "hjx"
3) "zls"
127.0.0.1:6379> rpoplpush name1 name2
"xwq"
127.0.0.1:6379> lrange name2 0 2
1) "xwq"
2) "hl"
3) "hjx"
127.0.0.1:6379> lrange name2 0 3
1) "xwq"
2) "hl"
3) "hjx"
4) "zls"


## 删除
# 从左边开始删除指定个数元素 lrem
127.0.0.1:6379> lrange name2 0 100
 1) "hl"
 2) "hl"
 3) "hl"
 4) "hl"
 5) "hl"
 6) "hl"
 7) "xwq"
 8) "hl"
 9) "hjx"
10) "zls"
11) "hl"
12) "hl"
13) "hl"
14) "hl"
127.0.0.1:6379> lrem name2 7 hl
(integer) 7
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"
3) "zls"
4) "hl"
5) "hl"
6) "hl"
7) "hl"

# 保留指定下标的元素,其余的都删除
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"
3) "zls"
4) "hl"
5) "hl"
6) "hl"
7) "hl"
127.0.0.1:6379> ltrim name2 0 1
OK
127.0.0.1:6379> lrange name2 0 100
1) "xwq"
2) "hjx"

## 改
127.0.0.1:6379> lrange name1 0 100
1) "wyk"
2) "hjx"
127.0.0.1:6379> lset name1 0 xwq
OK
127.0.0.1:6379> lrange name1 0 100
1) "xwq"
2) "hjx"

## 查
# 按照索引查询
127.0.0.1:6379> lindex name1 1
"hjx"
127.0.0.1:6379> lindex name1 0
"xwq"
127.0.0.1:6379> lindex name1 2
(nil)
127.0.0.1:6379> lindex name1 -1   //最后一个元素
"hjx"

## 发朋友圈
127.0.0.1:6379> lpush wechat 'monday hl sb'
(integer) 1
127.0.0.1:6379> lpush wechat 'tiusiday hl yiran sb'
(integer) 2
127.0.0.1:6379> lpush wechat 'wensiday hl always sb'
(integer) 3

## 查看朋友圈
127.0.0.1:6379> lrange wechat 0 -1
1) "wensiday hl always sb"
2) "tiusiday hl yiran sb"
3) "monday hl sb"

set(集合类型)

组1:1 2 3 4 5
组2: 1 3 5 7 9

交集:1 3 5
并集:1 2 3 4 5 7 9
差集:2 4 7 9
# 创建集合
127.0.0.1:6379> sadd zls_fans wyk hl
(integer) 2
127.0.0.1:6379> sadd tly_fans mls gaofei wyk
(integer) 3

# 查
## 查询集合中的元素,有就返回1 没有就返回0
127.0.0.1:6379> sismember zls_fans hl
(integer) 1
127.0.0.1:6379> sismember zls_fans cls
(integer) 0

## 查询集合中的所有元素
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"

## 查询集合中元素数量
127.0.0.1:6379> scard zls_fans
(integer) 2
127.0.0.1:6379> scard tly_fans
(integer) 3


## 比较集合中的差异,取前面集合的不同之处
127.0.0.1:6379> sdiff hl_fans tly_fans zls_fans
1) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS tly_fans
1) "wyk"
2) "mls"
3) "gaofei"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> sdiff hl_fans tly_fans
1) "hl"
2) "xiaoxuesheng"
127.0.0.1:6379> sdiff tly_fans hl_fans 
1) "wyk"
2) "gaofei"
127.0.0.1:6379> sdiff tly_fans hl_fans zls_fans
1) "gaofei"


## 比较之后的差异,存放到新的集合中
127.0.0.1:6379> sdiffstore resault tly_fans hl_fans 
(integer) 2
127.0.0.1:6379> KEYS *
1) "hl_fans"
2) "resault"
3) "name2"
4) "tly_fans"
5) "name1"
6) "wechat"
7) "zls_fans"
127.0.0.1:6379> type resault
set
127.0.0.1:6379> scard resault
(integer) 2
127.0.0.1:6379> 
127.0.0.1:6379> SMEMBERS resault
1) "wyk"
2) "gaofei"

## 交集(共同好友)
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> sinter hl_fans zls_fans
1) "hl"

## 并集
127.0.0.1:6379> sunion hl_fans zls_fans
1) "hl"
2) "wyk"
3) "mls"
4) "xiaoxuesheng"

## 将交集存入新集合
127.0.0.1:6379> sinterstore new_set hl_fans zls_fans
(integer) 1
127.0.0.1:6379> SMEMBERS new_set
1) "hl"

## 将并集存入新集合
127.0.0.1:6379> sunionstore new_set2 hl_fans zls_fans
(integer) 4
127.0.0.1:6379> SMEMBERS new_set2
1) "hl"
2) "wyk"
3) "mls"
4) "xiaoxuesheng"

## 取随机值
127.0.0.1:6379> srandmember zls_fans
"mls"



## 改
## 将集合的元素存入另一个集合 SMOVE
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "mls"
3) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
127.0.0.1:6379> SMOVE hl_fans zls_fans mls
(integer) 1
127.0.0.1:6379> SMEMBERS hl_fans
1) "hl"
2) "xiaoxuesheng"
127.0.0.1:6379> SMEMBERS zls_fans
1) "hl"
2) "wyk"
3) "mls"


## 删
127.0.0.1:6379> spop hl_fans
"hl"
127.0.0.1:6379> SMEMBERS hl_fans
1) "xiaoxuesheng"

## 删除指定元素,返回删除元素的个数
127.0.0.1:6379> srem zls_fans hl
(integer) 1
127.0.0.1:6379> SMEMBERS zls_fans
1) "wyk"
2) "mls"
127.0.0.1:6379> srem zls_fans xxx
(integer) 0


#### 无序的
127.0.0.1:6379> sadd zls_fans 111 222 333 444 555 666
(integer) 6
127.0.0.1:6379> SMEMBERS zls_fans
 1) "abc"
 2) "111"
 3) "mls"
 4) "123"
 5) "def"
 6) "333"
 7) "222"
 8) "456"
 9) "444"
10) "555"
11) "666"
12) "wyk"

sorted-set(有序集合)

应用场景:

排行榜应用,取TOP N操作
这个需求与上面需求的不同之处在于,前面操作以时间为权重,这个是以某个条件为权重,比如按顶的次数排序,这时候就需要我们的sorted set出马了,将你要排序的值设置成sorted set的score,将具体的数据设置成相应的value,每次只需要执行一条ZADD命令即可。

# 增
127.0.0.1:6379> zadd myzset 1 "one" 2 "two" 3 "three"

# 查
## 只查询成员
127.0.0.1:6379> zrange chengji 0 -1
1) "wyk"
2) "hl"
3) "zls"

## 查询成员和分数
127.0.0.1:6379> zrange chengji 0 -1 WITHSCORES
1) "wyk"
2) "1"
3) "hl"
4) "38"
5) "zls"
6) "100"

## 查询成员的索引
127.0.0.1:6379> zrank chengji wyk
(integer) 0
127.0.0.1:6379> zrank chengji zls
(integer) 2


## 查询成员数量
127.0.0.1:6379> zcard chengji 
(integer) 3

## 查看分数是指定范围的成员个数    30 <= score <=40
127.0.0.1:6379> zcount chengji 30 40
(integer) 1
127.0.0.1:6379> zcount chengji 30 101
(integer) 2

## 获取指定成员分数
127.0.0.1:6379> ZSCORE chengji wyk
"1"
127.0.0.1:6379> ZSCORE chengji zls
"100"

## 查看分数是指定范围的成员名
127.0.0.1:6379> zcount chengji 30 40
(integer) 1
127.0.0.1:6379> zrangebyscore chengji 30 40
1) "hl"

## +inf表示最后一个成员,-inf表示第一个成员,意思是:检索所有数据,然后从下标为2的数据开始再往后输出3:(N-1)个数据
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 3
1) "hjx"
2) "xwq"
3) "zls"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 2
1) "hjx"
2) "xwq"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 1
1) "hjx"
127.0.0.1:6379> zrangebyscore chengji -inf +inf  limit 2 4
1) "hjx"
2) "xwq"
3) "zls"

# 删
## 删除指定分数范围的成员,并返回删除的个数
127.0.0.1:6379> zrangebyscore chengji 30 40
1) "hl"
127.0.0.1:6379> zremrangebyscore chengji 30 40
(integer) 1

## 按指定索引范围删除,返回删除个数
127.0.0.1:6379> zremrangebyrank chengji 0 2
(integer) 3


## 倒序排名
127.0.0.1:6379> zrevrange chengji 0 -1 WITHSCORES
 1) "zls"
 2) "100"
 3) "hjx"
 4) "60"
 5) "xwq"
 6) "50"
 7) "hl"
 8) "38"
 9) "wyk"
10) "1"

## 按照分数段查找成员,并倒序排序
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES
1) "zls"
2) "100"
3) "hjx"
4) "60"
5) "xwq"
6) "50"
7) "hl"
8) "38"

## 按照分数查找成员,并倒序排序,然后按照索引号,取出指定的数据
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES limit 1 2
1) "hjx"
2) "60"
3) "xwq"
4) "50"
127.0.0.1:6379> zrevrangebyscore chengji 101 30 WITHSCORES limit 1 3
1) "hjx"
2) "60"
3) "xwq"
4) "50"
5) "hl"
6) "38"
posted @ 2022-09-03 13:21  Gabydawei  阅读(19)  评论(0编辑  收藏  举报