规定时间内获取并移除数据(阻塞式数据获取)
blpop key1 [key2] timeout //指定时间内取出并移除key值对应的value,若timeout超时仍未取出则返回空值(nil) 若本来没有 其他客户端在等待的时候添加了这个key的value则做操作 任务队列 brpop key1 [key2] timeout
移除指定数据
lrem key count value list类型数据操作注意事项list中保存的数据都是string类型的,数据总容量有限最多 2^32-1个元素
list具有索引概念,但操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出栈操作
获取全部操作结束数据的索引设置为-1
list可以对数据进行分页操作,通常第一页的信息来自list,第二页及更多的数据信息通过数据库进行查询加载
基础数据类型之:set存储需求:存储大量的数据,在查询方面提供更高的效率
存储结构:能够保存大量的数据,高效的内部存储机制,便于查询
set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值不允许为空
set存储结构是string类型的无序集合,内部存储时hash存储结构,因此添加、查找、删除的复杂度都是O(1)
set基本操作
添加不重复的数据
sadd key value
获取存储的所有数据
smembers key
删除数据
strem key member1 [member2]
获取集合数据总量
scard key
判断集合中是否包含指定数据
sismember key member
随机获取集合中指定数量的数据
srandmember key [count]
随机获取集合中某个数据并将该数据移出集合
apop key
两个集合的交、并、差集
sinter key1 [key2] sunion key1 [key2] adiff key1 [key2]
求两个集合的交、并、差集并存储到指定集合中
sinterstore destination key1 [key2] sunionstore destination key1 [key2] sdiffstore destination key1 [key2]
将指定数据从原始集合中移动到目标集合中
smove source destination member 注意事项
set类型不允许有重复数据,如果添加的数据在set中已存在,将只保留一份
set虽然与hash存储结构相同,但无法启用hash中存储值的空间
基础数据类型:sortedSet
存储需求:数据排序有利于数据的展示效果,需要提供一种可以根据自身特征进行排序的方式
存储结构:可以保存排序的数据
存储类型:在set的存储结构上添加可排序字段
基本操作
添加数据
zadd key scorel member [score2 member2]
获取全部数据
zrange key start stop [witchscores] zrevrange key star stop [witchscores]
删除数据
zrem key member [member ...]
按条件查询数据
zrangebyscore key min max [withscores] [limit] zrevrangebyscore key max min [withscores]
条件删除数据
zremrangebyrank key start stop //start stop 表示索引的开始结束位置 zremrangebyscore key min max //min max表示排序的最小到最大位置
获取集合数据数量
zcard key zcount key min max
集合交、并操作
zinterstore destination numkeys key [key ...] zunionstore destination key [key ...]