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