利用redis+mysql/mogodb实现点赞功能

需求:利用redis+mysql实现点赞功能;
优化:利用redis+mogodb实现点赞功能。
controller层:
    /**
     * 点赞博文
     * @param id
     * @return
     */
    @PutMapping("/like/{id}")
    public Result likeBlog(@PathVariable("id") Long id) {
        return blogService.likeBlog(id);
    }

    /**
     * 点赞博文momo
     * @param id
     * @return
     */
    @PutMapping("/likeMogo/{id}")
    public Result likeBlogMogo(@PathVariable("id") Long id) {
        return blogService.likeBlogMogo(id);
    }
service实现层:

1.普通数据库+redis实现:

    /**
     * 点赞博文
     * @param id 博文id
     * @return
     */
    @Override
    public Result likeBlog(Long id) {
        long begin = System.currentTimeMillis();
        log.info("点赞博文数据库, 开始时间:{}", begin);

        //1.获取当前登录用户
        Long userId = UserHolder.getUser().getId();
        //2.判断当前用户是否已经点赞  isMember判断值是否在set集合里面
        String key = BLOG_LIKED_KEY + id;
        Double score = redisTemplate.opsForZSet().score(key, userId.toString());
        //3.未点赞
        if (score==null){
            //3.1 数据库点赞数+1
            boolean isUpdate = this.update().setSql("liked = liked + 1").eq("id", id).update();
            //3.2 redis增加点赞记录 set集合 保存用户到Redis的set集合  zadd key value score
            long middle = System.currentTimeMillis();
            log.info("点赞博文数据库查询并更新, 耗时:{}", middle-begin);
            if (isUpdate){
                redisTemplate.opsForZSet().add(key, userId.toString(),System.currentTimeMillis());
            }
        }else {
            //4.已点赞
            //4.1 数据库点赞数-1
            boolean isUpdate = this.update().setSql("liked = liked - 1").eq("id", id).update();
            //2.2 redis删除点赞记录 set集合
            if (isUpdate){
                redisTemplate.opsForZSet().remove(key, userId.toString());
            }
        }

        long end = System.currentTimeMillis();
        log.info("点赞博文数据库, 结束时间:{}", System.currentTimeMillis());
        log.info("点赞博文数据库, 耗时:{}", end - begin);
        return Result.ok();
    }

2.mogodb数据库+redis实现:

    /**
     * 点赞博文momo
     * @param id
     * @return
     */
    @Override
    public Result likeBlogMogo(Long id) {
        long begin = System.currentTimeMillis();
        log.info("点赞博文mogo, 开始时间:{}", begin);
        //1.获取当前登录用户
        Long userId = UserHolder.getUser().getId();
        //2.判断当前用户是否已经点赞  isMember判断值是否在set集合里面
        String key = BLOG_LIKED_KEY + id;
        Double score = redisTemplate.opsForZSet().score(key, userId.toString());
        //3.未点赞
        if (score==null){
            //3.1 mogo库点赞数+1
            // 构建查询条件
            Query query = Query.query(Criteria.where("id").is(id));
            // 构建更新操作
            Update update = new Update().inc("liked", 1);
            // 执行更新操作
            UpdateResult updateResult = mongoTemplate.updateFirst(query, update, MogoBlog.class);
            long middle = System.currentTimeMillis();
            log.info("点赞博文mogo查询并更新, 耗时:{}", middle-begin);
            //3.2 redis增加点赞记录 set集合 保存用户到Redis的set集合  zadd key value score
            if (updateResult.getModifiedCount()>0){
                redisTemplate.opsForZSet().add(key, userId.toString(),System.currentTimeMillis());
            }
        }else {
            //4.已点赞
            //4.1 数据库点赞数-1
            // 构建查询条件
            Query query = Query.query(Criteria.where("id").is(id));
            // 构建更新操作
            Update update = new Update().inc("liked", -1);
            // 执行更新操作
            UpdateResult updateResult = mongoTemplate.updateFirst(query, update, MogoBlog.class);
            //2.2 redis删除点赞记录 set集合
            if (updateResult.getModifiedCount()>0){
                redisTemplate.opsForZSet().remove(key, userId.toString());
            }
        }

        long end = System.currentTimeMillis();
        log.info("点赞博文mogo, 结束时间:{}", System.currentTimeMillis());
        log.info("点赞博文mogo, 耗时:{}", end - begin);
        return Result.ok();
    }

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
你好!实现点赞和评论功能可以使用Spring Boot作为后端框架,Redis作为缓存数据库MySQL作为持久化数据库,UniApp作为前端框架。以下是一个简单的实现步骤: 1. 创建Spring Boot项目并配置MySQLRedis的连接。 2. 创建实体类,如User、Post等,用于表示用户和帖子。 3. 创建MySQL数据库表,包括用户表和帖子表。 4. 使用Spring Data JPA或MyBatis等框架进行数据库操作,实现用户和帖子的增删改查功能。 5. 在帖子表中添加字段用于存储点赞数和评论数。 6. 在后端编写点赞和评论的接口,分别处理点赞和评论的业务逻辑。 - 点赞接口可以接收用户ID和帖子ID,将点赞数加一,并更新数据库。 - 评论接口可以接收用户ID、帖子ID和评论内容,将评论数加一,并将评论保存到数据库。 7. 使用Redis进行缓存,可以将点赞数和评论数存储在Redis中,以提高访问速度。 - 在点赞接口中,先查询Redis中是否存在点赞数,如果存在则直接返回;否则从数据库中查询并存储到Redis中。 - 在评论接口中,同样先查询Redis中是否存在评论数,如果存在则直接返回;否则从数据库中查询并存储到Redis中。 8. 在UniApp中使用Vue.js等技术进行前端开发,调用后端提供的接口实现点赞和评论的功能。 - 在页面中展示帖子列表,并显示点赞数和评论数。 - 点击点赞按钮时,调用后端的点赞接口,并更新页面上的点赞数。 - 点击评论按钮时,调用后端的评论接口,并更新页面上的评论数。 以上是一个简单的实现方案,具体的细节还需要根据你的实际需求进行调整和完善。希望对你有所帮助!如有更多问题,请随时提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值