Hash应用场景
1.以电商购物车为例:以用户id为key,商品id为field,商品数量为value
添加商品-》hset cart:1001 10088 1
增加1088商品数量-》hincrby cart:1001 10088 1
获取1088商品数量-》hget cart:1001 10088
获取购物车的商品总数-》hlen cart:1001
删除1088商品-》hdel cart:1001 10088
获取购物车所有商品-》hgetall cart:1001
List数据结构
1.list可以实现的数据结构有stack:LPUSH+LPOP(FILO),队列:LPUSH+RPOP(FIFO),阻塞队列:LPUSH+BRPOP
LPUSH key value[value...]讲一个或多个value插入到key列表的表头
RPUSH key value[value...]将一个或多个值value插入到key列表的表尾
LPOP key 移除并返回key列表的头元素
RPOP key 移除并返回key列表的尾元素
LRANGE key start stop返回列表key中指定区间内的元素
BLPOP key [key...] timeout 从key列表弹出一个元素,若列表中没有元素,阻塞等待,timeout秒如果timeout=0一直阻塞等待
BRPOP key [key...] timeout从key列表表尾弹出一个元素
Set数据结构
SADD key member [member...]往集合key中存入元素,若存在忽略,不存在则创建(SADD like:{消息id} {用户id})
SREM key member [member...]从集合key中删除元素
SMEMBERS key获取集合key中所有元素
SCARD key获取集合key的元素个数
SISMEMBER key member判断member元素是否存在于集合key中
SRANDMEMBER key [count]从集合key中选出count元素,不删除key(抽奖的时候可以用到,随机抽取几位获奖人员)
SPOP key 【count】从集合key中选出count元素,删除key(抽不同等级的奖,抽到三等奖的人key删除,抽二等奖就不会存在)
SINTER key[key...]交集运算
SINTERSTORE destination key [key...]将交集结果存入新集合destination中
SUNION key [key...]并集运算
SUNIONSTORE destination key [key...]将并集结果存入新集合destination
SDIFF key [key...]差集运算
点赞:SADD like:{消息id} {用户id}
取消点赞:SREM like:{消息id} {用户id}
检查用户是否点过赞:SISMEMBER like:{消息id} {用户id}
获取点赞的用户列表:SMEMBERS like:{消息id}
获取点赞用户数:scard like:{消息id}