利用Redis相关技术点实现商品热卖排行榜

利用Redis相关技术点实现商品热卖排行榜

redis相关介绍

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/popadd/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了JavaC/C++C#PHPJavaScriptPerlObject-CPythonRubyErlang等客户端,使用很方便.


今天我们来利用Redis来实现一个大家在工作中都可能遇到的需求,热卖排行榜

话不多说开干!!!!!

  • 需求说明

1、本次我们实现一个每日热卖商品排行榜的需求
2、简单的设计俩张表:goods(商品表)、sell(销售记录表)
3、主要是将当日热卖的商品查询出来,利用Redis的有序集合进行大到小排序显示在前端页面

  • 技术列表

Springboot 2.1.2.RELEASE
Redis
freemarker
mybatis-plus 3.2.0
hutool-all


搭建项目基础环境
  • 首先我们来创建一个springboot项目,并且引入需要的依赖,后续需要的依赖后面用到在引入
    在这里插入图片描述
    所有的依赖如下:
<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-freemarker</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--mp-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.2.0</version>
        </dependency>

        <!--代码生成器-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.2.0</version>
        </dependency>

        <!-- sql分析器 -->
        <dependency>
            <groupId>p6spy</groupId>
            <artifactId>p6spy</artifactId>
            <version>3.8.6</version>
        </dependency>

        <!-- commons-lang3 -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.9</version>
        </dependency>
        <!--工具类-->
        <dependency>
            <groupId>cn.hutool</groupId>
            
  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Redis可以非常方便地实现排行榜功能。以下是一个使用Java实现Redis排行榜的示例代码: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.Tuple; import java.util.Set; public class RedisRankList { private Jedis jedis; private static final String RANK_LIST_KEY = "rank_list"; public RedisRankList() { jedis = new Jedis("localhost"); } public void addScore(String member, double score) { jedis.zadd(RANK_LIST_KEY, score, member); } public void removeMember(String member) { jedis.zrem(RANK_LIST_KEY, member); } public void incrementScore(String member, double increment) { jedis.zincrby(RANK_LIST_KEY, increment, member); } public Set<Tuple> getRankList() { return jedis.zrevrangeWithScores(RANK_LIST_KEY, 0, -1); } public static void main(String[] args) { RedisRankList rankList = new RedisRankList(); rankList.addScore("张三", 90); rankList.addScore("李四", 80); rankList.incrementScore("李四", 10); rankList.addScore("王五", 70); Set<Tuple> topScores = rankList.getRankList(); for (Tuple tuple : topScores) { System.out.println(tuple.getElement() + " : " + tuple.getScore()); } } } ``` 在上述示例代码中,我们使用了Jedis客户端连接到本地Redis服务器,并实现了添加成员分数、移除成员、增加成员分数、获取排行榜等功能。其中,`zadd`方法用于添加成员分数,`zrem`方法用于移除成员,`zincrby`方法用于增加成员分数,`zrevrangeWithScores`方法用于获取排行榜。通过运行该示例代码,我们可以得到以下结果: ``` 张三 : 90.0 李四 : 90.0 王五 : 70.0 ``` 可以看到,排行榜按照成员分数从高到低排序,且李四的分数已经增加了10分。这样,我们就成功地使用Java实现Redis排行榜功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值