利用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();
    }

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值