redis五种数据结构应用场景

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}

你可能感兴趣的:(redis五种数据结构应用场景)