有序集合(Zset)
zset是有序的,不可重复的集合,每个元素都有一个分数,根据分数从小到大排序。
我们来看一个抖音热搜的案例,视频每次被点击分数加1,然后取出分数最高的前十个.
//放入热门视频,初始点击量为0
Set<ZSetOperations.TypedTuple> set = new HashSet<>();
set.add(new DefaultTypedTuple("花木兰", 0d));
set.add(new DefaultTypedTuple("我们不一样", 0d));
set.add(new DefaultTypedTuple("春三月", 0d));
redisTemplate.opsForZSet().add("hot", set);
//模拟点击5次
redisTemplate.opsForZSet().incrementScore("hot", "花木兰", 5d);
//模拟点击3次
redisTemplate.opsForZSet().incrementScore("hot", "我们不一样", 3d);
//获取抖音热搜前十,reverse表示按照分数从大到小排列,index从0开始,第三个参数是闭区间
Set hot = redisTemplate.opsForZSet().reverseRange("hot", 0, 9);
hot.stream().forEach(System.out::println);
哈希表(hash)
hash类似java的map,可以按照key,value的形式存储,可用于分布式session,购物车等,下面看个购物车的案例。
//放入用户购物车,数量1
redisTemplate.opsForHash().put("shopcar:uid", "iphone12", 1);
redisTemplate.opsForHash().put("shopcar:uid", "ps5", 1);
//增加商品数量
redisTemplate.opsForHash().increment("shopcar:uid", "iphone12", 2);
//获取商品总数(分类数量)
long count = redisTemplate.opsForHash().size("shopcar:uid");
System.out.println(count);
//获取全部商品
Map map = redisTemplate.opsForHash().entries("shopcar:uid");
map.entrySet().stream().forEach(System.out::println);