admin 管理员组

文章数量: 887006

270

list

1、list类型

  • 数据存储需求: 存储多个数据,并对数据进入存储空间的顺序进行区分
  • 需要的存储结构: 一个存储空间保存多个数据,且通过数据可以体现进入顺序
  • list类型: 保存多个数据,底层使用双向链表存储结构实现


2、list基本操作

# 添加/修改数据
# 左添加
lpush key value1 [value2] ……  
# 右添加
rpush key value1 [value2] ……# 获取数据
# start stop 是索引,最后一个索引可以是 -1
lrange key start stop
lindex key index
# 获取长度
llen key# 获取并移除数据
lpop key
rpop key



右进(rpush)左查(lrange)和你输入的顺序是一样的!

-1表示最后一个,-2表示倒数第2个!


查看0号和2号索引是什么!

3、list 类型数据扩展操作

3.1、阻塞数据获取

阻塞式获取: 就是现在列表中没有数据,不代表将来没有数据,可以等!

# 规定时间内获取并移除数据blpop key1 [key2] timeout		
brpop key1 [key2] timeout
brpoplpush source destination timeout


现在list0里面没东西,就会阻塞了!

过了5s没东西就返回nil!


表示可以从那个若干个列表中 等数据!

会告诉你从那个地方取的!

4、list 类型数据扩展操作

4.1、业务场景


从中间拿数据?

# 移除指定数据
# count:移除几个 value:移除哪个值
# 比如有多个同样的value,从左删除几个
lrem key count value

模拟点赞顺序:



5、list 类型数据操作注意事项

  • list中保存的数据都是string类型的,数据总容量是有限的,最多2 32 - 1 个元素 (4294967295)。
  • list具有索引的概念,但是操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出栈操作
  • 获取全部数据操作结束索引设置为-1
  • list可以对数据进行分页操作,通常第一页的信息来自于list(第一页缓存中查,较快!),第2页及更多的信息通过数据库的形式加载

6、list 类型应用场景



本文标签: 270